【mysql】单表使用索引常见的索引失效

1. 全值匹配我最爱

  全值匹配我最爱指的是,查询的字段按照顺序在索引中都可以匹配到!

  SQL 中查询字段的顺序,跟使用索引中字段的顺序,没有关系。优化器会在不影响SQL 执行结果的前提下,给

你自动地优化。

2.  最佳左前缀法则

 

 

 

  查询字段与索引字段顺序的不同会导致,索引无法充分使用,甚至索引失效!
  原因:使用复合索引,需要遵循最佳左前缀法则,即如果索引了多列,要遵守最左前缀法则。指的是查询从索
引的最左前列开始并且不跳过索引中的列。
  结论:过滤条件要使用索引必须按照索引建立时的顺序,依次满足,一旦跳过某个字段,索引后面的字段都无
法被使用。

3. 不要在索引列上做任何计算

  不在索引列上做任何操作(计算、函数、(自动or 手动)类型转换),会导致索引失效而转向全表扫描。

3.1 在查询列上使用了函数

  

 

 

  结论:等号左边无计算!

3.2 在查询列上做了转换

 

 

  结论:等号右边无转换!

 

4. 索引列上不能有范围查询

 

 

   建议:将可能做范围查询的字段的索引顺序放在最后

 

5. 尽量使用覆盖索

  即查询列和索引列一直,不要写select *!

 

 6. 使用不等于(!= 或者<>)的时候索引失效

  mysql 在使用不等于(!= 或者<>)时,有时会无法使用索引会导致全表扫描。

 

 7. 字段的is not null 和is null

 

   is not null 用不到索引,is null 可以用到索引。

 

8. like 的前后模糊匹配

 

 

   前缀不能出现模糊匹配!

9. 减少使用or

  使用or时不走索引。

 

 

  使用union all 或者union 来替代:

 10. 口诀

  全职匹配我最爱,最左前缀要遵守;
  带头大哥不能死,中间兄弟不能断;
  索引列上少计算,范围之后全失效;
  LIKE 百分写最右,覆盖索引不写*;
  不等空值还有OR,索引影响要注意;
  VAR 引号不可丢,SQL 优化有诀窍。

 

----尚硅谷_mysql_高级学习笔记

posted @ 2020-05-05 20:12  天际星痕  阅读(1500)  评论(0编辑  收藏  举报