索引失效的情况

  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会自行选择最优的其中一个作为索引,其他的单列索引则失效。
MySQL索引失效通常发生在以下几种情况下: 1. **全表扫描(Full Table Scan)**:当查询不包含索引中的条件,或者查询的条件使得索引的范围搜索变为从表的开始到结束,MySQL会执行全表扫描,此时索引就无法发挥作用。 2. **索引上有函数操作**:如果查询中对索引进行了函数操作(如`LIKE`, `BETWEEN`, `SUBSTRING`等),导致索引无法直接使用,MySQL会忽略索引。 3. **索引键值重复**:如果索引中有大量或全部相同的值,索引可能无法区分记录,比如在复合索引中,第一个字段的值相同。 4. **覆盖索引未被利用**:对于那些查询只需要索引本身就可以完成的情况,如果查询结果包括了索引之外的数据,MySQL需要回表获取,索引就失效了。 5. **索引有NULL值**:在某些数据库引擎(如InnoDB)中,NULL值无法在索引中存储,所以含有NULL值的创建的索引会部分无效。 6. **索引选择性低**:索引的选择性指的是不同唯一值的数量与总行数的比率,低选择性的索引在过滤数据时效率较低。 7. **动态SQL或预编译**:如果使用动态SQL或存储过程创建的索引,可能会因为每次运行时使用的条件不同而导致索引失效。 遇到索引失效,可以通过分析查询语句、优化查询策略、调整索引设计或重构查询来改善性能。如果你遇到特定的问题,可以详细描述查询和表结构,以便更精确地诊断原因。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值