文章详情页
mysql优化 - mysql 模糊查询和order by同用如何建立索引?
浏览:193日期: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. 下一个页面的三角在上面一个页面会出现,在缩放的时候会遮住文字。2. android - mac平台运行快捷键咋按3. mysql优化 - mysql 多表联合查询,求一个效率最高的查询4. weex - Android 原生Vue.js 使用 justify-content: flex-end; 不起作用5. 数据库 - mysql中怎样修改带点的字段名的位置?6. python - Django ManyToManyField 字段数据在 admin后台 显示不正确,这是怎么回事?7. php由5.3升级到5.6后,登录网站,返回的是php代码,不是登录界面,各位大神有知道的吗?8. 为什么span的color非要内联样式才起作用?9. mysql 能不能创建一个 有列级函数 的联合视图?10. javascript - vue-cli热更新的问题【webpack配置】
排行榜

网公网安备