MySQL索引有序性分析

说明:本文中所有叙述均基于MySQL 5.6版本 ,Innodb引擎 ,数据库隔离级别为可重复读

业务需求中经常会遇到排序要求,可以使用SQL提供的order by关键字解决。利用索引有序性,可以提升order by的效率,避免出现file_sort。

在阿里的编程规范中特别有一条对于索引有序性的规范

本文主要针对这条规范进行深入说明及示例验证。

DROP TABLE IF EXISTS `test4`;

CREATE TABLE `test4` (
  `a` int NOT NULL,
  `b` int NOT NULL,
  `c` int  NOT NULL,
  `d` int  NOT NULL,
  KEY `ind_test4` (`a`,`b`,`c`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

INSERT INTO `test4` (`a`, `b`, `c`,`d`) VALUES(1,2,3,4);
INSERT INTO `test4` (`a`, `b`, `c`,`d`) VALUES(5,6,7,8);
INSERT INTO `test4` (`a`, `b`, `c`,`d`) VALUES(9,10,11,12);
INSERT INTO `test4` (`a`, `b`, `c`,`d`) VALUES(13,14,15,16);
INSERT INTO `test4` (`a`, `b`, `c`,`d`) VALUES(17,18,19,20);

以上述test4表为例

示例结果备注
SELECT * FROM test4  WHERE a=1 ORDER BY cUSING filesort 
SELECT * FROM test4  WHERE a=1 ORDER BY a,cUSING filesort 
SELECT * FROM test4  WHERE a IN (1,5) ORDER BY bUSING filesort 
SELECT * FROM test4  WHERE a>1 ORDER BY a USING filesort 

SELECT * FROM test4  WHERE a>1 ORDER BY b 

USING filesort 
SELECT * FROM test4  WHERE a=1 AND b>1 ORDER BY cUSING filesort 
SELECT * FROM test4  WHERE a=1 ORDER BY a     无需filesort 
SELECT * FROM test4  WHERE a=1 ORDER BY b 无需filesort 
SELECT * FROM test4 WHERE a=1 ORDER BY b,c无需filesort 
SELECT * FROM test4  WHERE a=1 ORDER BY a,b无需filesort 
SELECT * FROM test4  WHERE a=1 ORDER BY a,b,c无需filesort 
SELECT * FROM test4  WHERE a=1 AND b>1 ORDER BY b无需filesort 

规律:

1、idx_a_b_c,那么如何确定某个字段是有序的呢?a在索引的最前面,肯定是有序的,b在第二个位置,只有在a唯一确定一个值的时候,b才是有序的,如果a有多个值,那么b 将不一定有序,同理,c也是类似

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值