索引失效的场景主要有那些

1、不满足最左匹配原则

当使用联合索引时,查询条件没有从最左索引列开始,或者跳过了索引中的列,那么索引可能会失效。例如,对于联合索引(sex, age, name),如果查询条件只包含了sex和name而没有age,那么索引可能不会被使用。

2、在索引列上使用函数

如果在索引列上使用了函数或表达式,那么索引可能会失效。例如,使用SUBSTR、DECODE、INSTR等函数对索引列进行运算。

3、查询条件使用了非索引列

如果查询条件中的列没有被索引,那么索引自然不会被使用。

4、使用了全表扫描

当查询的数据量非常大,或者查询条件导致索引无法被有效使用时,数据库可能会选择进行全表扫描,此时索引会失效。

5、使用了NOT IN、NOT EXISTS、<>等操作符

这些操作符在查询时可能会导致结果集很大,数据库可能会选择不使用索引而进行全表扫描。

6、使用了LIKE操作符并且百分号在前

如LIKE "%abc",这样的查询条件不能有效地利用索引,因为需要扫描所有行来确定哪些行匹配。

7、单独引用复合索引里非第一位置的索引列

对于复合索引,如果查询条件只引用了非第一位置的索引列,那么索引可能不会被使用。

8、字符型字段为数字时在WHERE条件里不添加引号

这可能会导致数据库将数字与字符型字段进行隐式转换,从而无法有效利用索引。

9、变量类型不匹配

例如,当变量采用的是times变量,而表的字段采用的是date变量时,或者相反情况,可能会导致索引失效。

10、ORDER BY语句中没有加WHERE或LIMIT关键字

如果ORDER BY语句中没有加WHERE或LIMIT关键字,数据库可能会选择全表扫描来满足排序需求,此时索引会失效。

相关推荐
大龄码农-涵哥3 分钟前
Java 调用 LLM 全解析:ChatGPT、Claude、通义千问一网打尽
java·开发语言·chatgpt
小新同学^O^4 分钟前
简单学习 --> JVM
java·开发语言·python
Hello.Reader6 分钟前
算法基础(十一)—— 递归树如何看懂分治算法的运行时间
java·算法·排序算法
程序员三明治12 分钟前
【AI】一文讲清 RAG:从大模型局限到企业级知识库落地流程
java·人工智能·后端·ai·大模型·llm·rag
Devin~Y13 分钟前
大厂 Java 面试实录:Spring Boot/Cloud、Kafka、Redis、JVM、K8s、RAG 一条龙(小Y翻车版)
java·jvm·spring boot·redis·spring cloud·kafka·kubernetes
lightqjx14 分钟前
【Linux】第一个小程序:进度条
linux·服务器·学习·缓存·c·进度条实现
无限进步_14 分钟前
【C++】深入右值引用:移动语义与完美转发
java·开发语言·c++
霑潇雨15 分钟前
原生 Zookeeper 实现分布式锁案例
java·分布式·zookeeper·云原生·maven
小王C语言15 分钟前
【线程同步与互斥】:互斥量(锁)、条件变量(唤醒等待线程)、生产者消费者模型
java·开发语言
我命由我1234518 分钟前
Jetpack Compose - 设置 Compose 编译器、设置 Compose 依赖项
android·java·java-ee·kotlin·android jetpack·android-studio·android runtime