索引失效的情况

it2026-03-09  4

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