文章详情页
mysql优化 - mysql 模糊查询和order by同用如何建立索引?
浏览:103日期:2022-06-11 13:49:18
问题描述
比如现在有这样一个mysql语句:
select * from city where city_name like ’%hf%’ order by created_at;
这样的sql语句如何建立索引呢,如果是建立复合索引,使用:
key(created_at,city_name)
这个由于created_at在前面,根据索引的最左匹配原则退化成了key(created_at).
key(city_name,created_at)
肯定也不行,前面是模糊查询,这个复合索引退化成了key(city),那么这种情况只能建立单个的索引列来解决问题吗?请教各位大大.
问题解答
回答1:前后都是%是不走索引的,都没有索引退化的问题,要么改sql成前缀匹配要么加全文索引(对于短字串并不合适),再有就是对于这种基本不变的数据在应用里面是可以放到搜索引擎里的,可以利用到它的分词器检索
相关文章:
1. mysql 一个sql 返回多个总数2. mysql存储过程变量值为NULL3. mysql - 如何用数据库中某时间字段的 ’时分秒’ 减去 早上九点(09:00:00) 得到分钟数4. 请教使用PDO连接MSSQL数据库插入是乱码问题?5. javascript - onclick事件点击不起作用6. navicat - 数据库建索引选择的是hash,但保存后自动变成了btree|实践时mysql四种引擎都有什么要注意的?7. mysql - phpmyadmin怎么分段导出数据啊?8. html5 - 有什么好的方法防止微信公众号发红包被刷么?9. mysql - sql 中 group 和field 查询问题。10. centos环境,mysql可以用非root(普通用户)安装么?
排行榜
