索引失效的情况

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值