MySQL中为避免索引失效所需注意的问题

一、索引介绍

索引介绍

二、索引的优势与劣势

1、优势
  • 类似于书籍的目录索引,提高数据检索的效率,降低数据库的IO成本。
  • 通过索引列对数据进行排序,降低数据排序的成本,降低CPU的消耗。
2、劣势
  • 实际上索引也是一张表,该表中保存了主键与索引字段,并指向实体类的记录,所以索引列也是要占用空间 的。
  • 虽然索引大大提高了查询效率,同时却也降低更新表的速度,如对表进行INSERT、UPDATE、DELETE。因为 更新表时,MySQL 不仅要保存数据,还要保存一下索引文件每次更新添加了索引列的字段,都会调整因为更新所带来的键值变化后的索引信

三、准备环境

image.png

四、避免索引失效的注意点

1、全值匹配

全值匹配 ,对索引中所有列都指定具体值。该情况下,索引生效,执行效率高。
image.png

2、最左前缀法则

如果索引了多列,要遵守左前缀法则。指的是查询从索引的左前列开始,并且不跳过索引中的列。
创建索引的方式:
image.png
Ⅰ、匹配最左前缀法则,走索引
image.png
Ⅱ、违背最左前缀法则,索引失效
image.png
Ⅲ、如果符合最左前缀法则,但是出现跳跃某一列,则只有左列索引生效
image.png

3、范围查询右边的列,不能使用索引

如下,范围查询之后的address没有使用索引
image.png

4、不要在索引列上进行运算操作,索引将失效

image.png

5、字符串不加单引号,造成索引失效

由于,在查询时,没有对字符串加单引号,MySQL的查询优化器,会自动的进行类型转换,造成索引失效。
image.png

6、尽量使用覆盖索引,避免select *

image.png
image.png

7、or前面的列有索引,后面没有,那么索引不会被使用

示例,name 字段是索引列 , 而 createtime 不是索引列,中间是 or 进行连接是不走索引的 :
image.png

8、以%开头的like模糊查询,索引失效

如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。
image.png
解决方案:覆盖索引
image.png

9、如果mysql评估使用索引比全表更慢,则不使用索引

image.png

10、is NULL,is not NULL有时索引失效

image.png
这里索引失效的原因其实就是上面的第九条

11、in 走索引, not in 索引失效。

image.png

12、尽量使用复合索引,而少使用单列索引 。

image.png

2020-9-6

posted @ 2021-01-23 22:42  pedro7  阅读(78)  评论(0编辑  收藏  举报