索引之----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

posted @ 2019-08-01 12:10  白巧  阅读(414)  评论(0编辑  收藏  举报