- 在组合索引中,不符合最左前缀法则,索引失效。
- 范围查询
右边
的列,如果有索引,则失效。 - 在索引字段上进行运算操作,索引将失效。
- 字符串不加单引号,索引将失效。
- 尽量不要使用or,会让索引失效,无论是多列索引还是单列索引。多列索引如果select后面跟的是索引字段,也就是覆盖索引,则不会失效;网上说使用or,想要让索引生效,需要将or条件中的每个列添加索引,即可,但是试验过后,依然无效。
- 模糊查询like ,开头是%的,索引失效,可以使用覆盖索引来解决。
- mysql评估全表扫描和使用索引扫描哪个更快,如果全表扫描更快,mysql会使用全表扫描,导致索引失效。
- is null 和 is not null 有时索引失效,有时失效,与第7点有关。
- in 走索引,not in不走索引,不是绝对的,看in后面跟的数据量。
- 存在多个单列索引作为查询条件时,mysql会自行选择最优的其中一个作为索引,其他的单列索引则失效。
索引失效的情况
最新推荐文章于 2024-07-02 17:19:12 发布