文章详情页
mysql优化 - mysql 模糊查询和order by同用如何建立索引?
浏览:133日期: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. css - 如何使用 vue transition 实现 ios 按钮一样的平滑切换效果2. angular.js - 关于$apply()3. mysql - 把一个表中的数据count更新到另一个表里?4. 网络传输协议 - 以下三种下载方式有什么不同?如何用python模拟下载器下载?5. mysql数据库做关联一般用id还是用户名6. 关于python切片的问题7. linux - 升级到Python3.6后GDB无法正常运行?8. mysql 里边,自增长id,写数据时,是先把数据写进去,然后再给这条数据一个id,还是先给id,然后再把要插入的数据写进去9. 多维数组如何在视图中渲染10. javascript - 前端怎样实现图片剪切一部分上传呢?像微信或者QQ上传那样呢?用的啥技术
排行榜
