mysql 模糊查询和order by同用如何建立索引?

发布于 2022-09-05 01:34:10 字数 392 浏览 11 评论 0

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

你的心境我的脸 2022-09-12 01:34:10

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文