欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 培训 > 什么情况下索引会失效?

什么情况下索引会失效?

2025/5/7 11:28:52 来源:https://blog.csdn.net/qq_41623592/article/details/142624404  浏览:    关键词:什么情况下索引会失效?

什么情况下索引会失效?

违反最左前缀法则

给出本文部分名词定义:
索引列,定义某索引时,使用到的列,定义中的先后顺序决定各列优先级,最先写的列,优先级最高,使用索引时最先使用该列的条件筛选;
最左前缀,索引使用到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 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词