MySQL索引失效的场景

文章讲述了在MySQL数据库中影响索引效率的多种情况,包括LIKE操作符的使用方式,数据量小可能导致全表扫描,OR语句中单侧索引无效,索引列上的类型转换和函数应用,列对比导致索引失效,数据分布不均匀,索引列长度过长,重复值以及不等于操作符的使用等。了解这些场景有助于优化查询性能。
摘要由CSDN通过智能技术生成

1.like 以%开头,索引无效;当like前缀没有%,后缀有%时,索引有效。

2.数据库表数据量过小

如果表的数据量非常小,则MySQL可能不会使用索引,因为它认为全表扫描的代价更小。

3.or语句前后没有同时使用索引

当or左右查询字段只有一个是索引,该索引失效,只有当or左右查询字段均为索引时,才会生效

4.索引列上进行了类型转换

如果在索引列上执行类型转换,MySQL将无法使用索引来加速查询。

5.索引列用了函数

例如:  select * from user  where SUBSTR(height,1,2)=17;

6.列对比

例如: select * from user where id=height

如果把两个单独建了索引的列,用来做列对比时索引会失效。

7.数据分布不均匀

如果表中某些值的出现频率非常高,那么MySQL可能会认为使用全表扫描代价更小,而不使用索引。

8.索引列的长度过长

如果索引列的长度过长,MySQL将会使用更多的内存来存储索引,可能会影响性能。

9.索引列上存在重复值

如果索引列上存在重复值,MySQL将无法使用索引来加速查询。

10.在索引字段上使用not,<>,!=

不等于操作符是永远不会用到索引的,因此对它的处理只会产生全表扫描。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值