索引之----mysql联合索引
重要概念:
1.对于mysql来说,一条sql中,一个表无论其蕴含的索引有多少,但是有且只用一条。
2.对于多列索引来说(a,b,c)其相当于3个索引(a),(a,b),(a,b,c)3个索引,又由于mysql的索引优化器,其where条件后的语句是可以乱序的,比如(b,c,a)也是可以用到索引。如果条件中a,c出现的多,为了更好的利用索引故最好将其修改为(a.c,b)。
ICP概念:
1. Index range 先确认索引的起止范围。
2. Index Filter 索引过滤。
3. Table Filter 表过滤。
mysql5.6后提出的icp就是多了第二步,以前Index filter是放在数据上操作的,现在5.6后多了第二步,因此效率提高了很多。
【优化口诀】
全值匹配我最爱,最左前缀要遵守;
带头大哥不能死,中间兄弟不能断;
索引列上少计算,范围之后全失效;
LIKE百分写最右,覆盖索引不写*;
不等空值还有OR,索引影响要注意;
VAR引号不可丢, SQL优化有诀窍。
转载单列索引与联合索引的区别测试 https://blog.csdn.net/Abysscarry/article/details/80792876