一、单表

创建索引之前:type=ALL全表扫描,Extra里面的Using filesort(文件内部排序)

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

MySQL索引优化 Mysql 第1张

根据where后面的条件创建CREATE INDEX idx_article_ccv ON article(category_id,comments,views);

MySQL索引优化 Mysql 第2张

   可以看出type由ALL变成了range,但是Extra里面的Using filesort(文件内部排序)未解决

   此时删除索引:DROP INDEX idx_article_ccv ON article;

   重新建立CREATE INDEX idx_article_ccv ON article(category_id,views);

MySQL索引优化 Mysql 第3张

 

此时完美解决!!

二、双表

 创建索引之前:type=ALL全表扫描

MySQL索引优化 Mysql 第4张

 此时有两个表,里面都有字段card,但是现在不知道应该建左表class还是右表book,所以可以先建右表book,查看之后再进行优化

ALTER TABLE book ADD index  Y('card');

MySQL索引优化 Mysql 第5张

此时可以明显看到book表得到优化type=ref,但是class表未得到改变,于是删除索引DROP INDEX Y ON book;

现在加左表class: ALTER TABLE class ADD INDEX Y ('card');

MySQL索引优化 Mysql 第6张

此时看到class表的type=index,建立在右表type=ref,因为ref>index,rows=40>前者的21,所以权衡之间,得到:

  左右连接时,左连接建右表索引,右连接建左边索引,因为这是由于左右连接特性决定的,左连接左表一定都有,右表成了关键点,所以右表一定要建立索引,右连接反之。

 三、三表

  创建索引之前:type=ALL全表扫描,rows=60

MySQL索引优化 Mysql 第7张

 

  从上面两表或查询中总结出左连接建右表,那么这里给phone表和book表创建索引

MySQL索引优化 Mysql 第8张

  创建好索引后查看结论

MySQL索引优化 Mysql 第9张

 

此时看到后两行的type都为ref,中rows=22,优化的很好,因此索引最好建立在经常查询的字段中

四、索引失效

MySQL索引优化 Mysql 第10张

最佳左前缀法则:如果索引了多列,指的是查询从索引的最左抢前列开始并且不跳过索引中的列

问题:如何解决like %字符串%索引失效

  1、百分号只写右边aa%不失效

  2、使用覆盖索引【何为覆盖索引见我的上一篇文章MySQL的explain中有解释】

小结:

MySQL索引优化 Mysql 第11张

优化口诀:

MySQL索引优化 Mysql 第12张

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄