mysql索引失效_「温故而知新」 mysql常见的索引失效场景

有如下测试表test1130,建有

组合索引index_test(name,addr,age),

普通索引index_hair(hair)、index_intro(intro)

e94fad266b48f593bf18ba558cb28f6b.png

1、组合索引最左原则index_test(name,addr,age):

SELECT * FROM test1130 WHERE addr=1;SELECT * FROM test1130 WHERE age=1;//跳过name,用不到任何索引
SELECT * FROM test1130 WHERE name='小明' and age=12;//name索引能用到,age索引用不到
SELECT * FROM test1130 WHERE name='小明' and addr>'成都' and age=12;//范围查找的右边都用不到,即addr>'成都' 的右边age的索引用不到

2、普通索引like %开头

SELECT * FROM test1130 WHERE intro LIKE '%强';//like 以%开头,索引无效;当like前缀没有%,后缀有%时,索引有效。

3、使用or

SELECT * FROM test1130 where intro='hello' or updated='2019-11-30 17:57:22'//or语句前后没有同时使用索引。当or左右查询字段只有一个是索引,该索引失效,只有当or左右查询字段均为索引时,才会生效

4、数据出现隐式转换时

SELECT * FROM test1130 where intro=12;//如 '12' 写成 12 会自动转换为int型,使索引无效,产生全表扫描。

5、对索引字段进行计算操作、字段上使用函数。

SELECT * FROM test1130 where LEFT(intro,5)='hello' ;//索引列通过计算
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值