什么情况下索引会失效?

什么情况下索引会失效?

违反最左前缀法则

给出本文部分名词定义:
索引列,定义某索引时,使用到的列,定义中的先后顺序决定各列优先级,最先写的列,优先级最高,使用索引时最先使用该列的条件筛选;
最左前缀,索引使用到name、age、height、weight四列,name age height是最左前缀,name是最左前缀,name age weight不是,而name age是;

在某索引使用多列的情况下,要正确使用该索引的话:

  1. 要按照索引列的最左前缀方案添加where条件;
  2. 各where条件按照索引列的最左前缀生效,不完全是最左前缀的(开头满足最左前缀,中间某索引列跳过,后续又出现部分索引列的情况)开头满足最左前缀的部分走索引,后续序列失效;

若查询条件不包含第一个索引列,则索引不生效。

范围查询

范围查询字段其右的列,不会走索引。

索引列上的运算操作

例如某表以name字段建立了索引,在查询时,在 where 中使用 substring 截取该字段。
例:select * from t where substring(name,2,2)='aa'
而推测 select * from t where substring('aaaaaa',2,2)=name 是会生效索引的,注意区分。

字符串不加单引号,可能使得字符串字段产生类型转换,导致索引失效

模糊查询可能会导致索引失效

以%开头的Like模糊查询,导致索引失效;

如果仅在尾部使用%模糊匹配,则索引不会失效。

声明:本文使用八爪鱼rpa工具从gitee自动搬运本人原创(或摘录,会备注出处)博客,如版式错乱请评论私信,如情况紧急或久未回复请致邮 xkm.0jiejie0@qq.com 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值