mysql 中最左前缀要求的必要性
问题:
MySQL 中联合索引有最左前缀的要求,即需要查询最左边的列才能使用索引。优化器为什么不能自动调整顺序,使得满足最左前缀条件?
回答:
对最左前缀的理解有误。
如 index(‘user_id’, ‘created_at’) 索引,虽然查询中 created_at 排在最左,但 user_id 同样满足最左前缀条件,因为 user_id 位于索引的最左边。
最左前缀规则如下:
- 使用索引的查询条件中,首列必须出现在联合索引的最左边。
- 后续列可以任意排列,只要满足第一个规则即可。
示例:
联合索引 (a, b, c) 的查询示例:
- where a, b, c
- where a, c
- where a, b
- where a
只有满足最左前缀的查询才能走索引,例如:
- where b, c 不能走索引(因为 a 未出现)
注意:
- where 子句中列的顺序可以任意组合,但须满足最左前缀规则。
- order 子句中,首列也必须满足最左前缀条件。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
【小浪云服务商 - 服务器12元起 - 挂机宝5元起】
THE END
暂无评论内容