mysql优化 - mysql 模糊查询和order by同用如何建立索引?
高洛峰
高洛峰 2017-06-14 10:50:40
[MySQL讨论组]

比如现在有这样一个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),那么这种情况只能建立单个的索引列来解决问题吗?
请教各位大大.

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(1)
仅有的幸福

前后都是%是不走索引的,都没有索引退化的问题,要么改sql成前缀匹配要么加全文索引(对于短字串并不合适),再有就是对于这种基本不变的数据在应用里面是可以放到搜索引擎里的,可以利用到它的分词器检索

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号