只有当索引的列顺序和order by字句的顺序完全一致,并且所有的列的要么是升序排列,要么全部是降序排列,所有的列的排序方向都一致时,MySQL才能使用索引来对结果进行排序,如果查询需要关联多张表,则只有当order by子句引用的字段全部为第一张表时,才能使用索引做排序。
order by子句和查找语句的限制是一样的,即需要满足最左匹配,最左前缀的要求,否则无法利用索引排序,但是有个例外,order by可以不满足这个条件也可以进行索引排序,那就是前导列是常量的时候。如果where子句和join子句对这些列指定了常量,就可以“弥补”索引的不足。也就是说where后面的字段的查询值是常量,然后order by后面。。看下面的例子
不能用索引的情况:
如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!
添加我为好友,拉您入交流群!
请使用微信扫一扫!