一、索引介绍
二、索引的优势与劣势
1、优势
- 类似于书籍的目录索引,提高数据检索的效率,降低数据库的IO成本。
- 通过索引列对数据进行排序,降低数据排序的成本,降低CPU的消耗。
2、劣势
- 实际上索引也是一张表,该表中保存了主键与索引字段,并指向实体类的记录,所以索引列也是要占用空间 的。
- 虽然索引大大提高了查询效率,同时却也降低更新表的速度,如对表进行INSERT、UPDATE、DELETE。因为 更新表时,MySQL 不仅要保存数据,还要保存一下索引文件每次更新添加了索引列的字段,都会调整因为更新所带来的键值变化后的索引信
三、准备环境
四、避免索引失效的注意点
1、全值匹配
全值匹配 ,对索引中所有列都指定具体值。该情况下,索引生效,执行效率高。
2、最左前缀法则
如果索引了多列,要遵守左前缀法则。指的是查询从索引的左前列开始,并且不跳过索引中的列。
创建索引的方式:
Ⅰ、匹配最左前缀法则,走索引
Ⅱ、违背最左前缀法则,索引失效
Ⅲ、如果符合最左前缀法则,但是出现跳跃某一列,则只有左列索引生效
3、范围查询右边的列,不能使用索引
如下,范围查询之后的address没有使用索引
4、不要在索引列上进行运算操作,索引将失效
5、字符串不加单引号,造成索引失效
由于,在查询时,没有对字符串加单引号,MySQL的查询优化器,会自动的进行类型转换,造成索引失效。
6、尽量使用覆盖索引,避免select *
7、or前面的列有索引,后面没有,那么索引不会被使用
示例,name 字段是索引列 , 而 createtime 不是索引列,中间是 or 进行连接是不走索引的 :
8、以%开头的like模糊查询,索引失效
如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。
解决方案:覆盖索引
9、如果mysql评估使用索引比全表更慢,则不使用索引
10、is NULL,is not NULL有时索引失效
这里索引失效的原因其实就是上面的第九条
11、in 走索引, not in 索引失效。
12、尽量使用复合索引,而少使用单列索引 。
2020-9-6