索引失效的14种常见场景

在 MySQL 中,索引有时可能会失效,导致查询性能下降。以下是常见的 14 种场景,在这些场景下,索引可能会失效

1. 使用 OR 连接多个条件

  • 场景: 当查询中包含 OR 时,如果 OR 连接的多个条件中有一个没有使用索引,可能会导致索引失效。
  • 例子:
    SELECT * FROM employees WHERE age = 30 OR name = 'John';
    这个查询中, age = 30 可能使用索引,但 name = 'John' 没有索引时,MySQL 会放弃使用索引。

2. 在查询中使用函数

  • 场景: 如果查询中在索引列上应用了函数,索引可能失效。
  • 例子:
    SELECT * FROM employees WHERE YEAR(birthdate) = 1990;
    这里对 birthdate 使用了 YEAR() 函数,导致索引失效。

3. 使用 LIKE 开头的模糊匹配

  • 场景: 当 LIKE 操作符以通配符 % 开头时,索引会失效。
  • 例子:
    SELECT * FROM employees WHERE name LIKE '%John';
    由于 % 位于开头,MySQL 无法使用索引优化查询。

4. 在查询条件中使用 NOT

  • 场景: 使用 NOT 操作符时,索引可能会失效,尤其是与 INLIKE 一起使用时。
  • 例子:
    SELECT * FROM employees WHERE NOT age = 30;
    NOT 会导致索引失效,MySQL 可能会选择全表扫描。

5. 使用 IS NULLIS NOT NULL

  • 场景: 当查询条件使用 IS NULLIS NOT NULL 时,索引可能不会被使用。
  • 例子:
    SELECT * FROM employees WHERE salary IS NULL;
    使用 IS NULL 时,索引可能不会被有效利用。

6. 范围查询后再进行其他条件筛选

  • 场景: 使用范围查询( BETWEEN<> 等)后,再添加其他条件,索引可能失效。
  • 例子:
    SELECT * FROM employees WHERE age BETWEEN 30 AND 40 AND name = 'John';
    这里, age 使用了范围查询, name 的条件可能无法使用索引。

7. 联合索引的列顺序不匹配

  • 场景: 使用联合索引时,如果查询的列顺序与索引创建时的顺序不匹配,索引可能会失效。
  • 例子:
    CREATE INDEX idx_name_age ON employees (name, age);
    SELECT * FROM employees WHERE age = 30 AND name = 'John';
    如果 age 在联合索引中排在 name 后面,这种查询会导致索引失效。

8. 使用 DISTINCTGROUP BY

  • 场景: 如果查询中使用了 DISTINCTGROUP BY,索引可能无法被完全利用。
  • 例子:
    SELECT DISTINCT name FROM employees WHERE age = 30;
    DISTINCTGROUP BY 可能导致索引不完全被利用。

9. 在查询中使用 LIMIT

  • 场景: 当查询包含 LIMIT 子句时,如果没有明确的排序索引,MySQL 可能无法使用索引。
  • 例子:
    SELECT * FROM employees WHERE age = 30 LIMIT 10;
    如果没有 ORDER BY,MySQL 可能不会使用索引来限制结果数量。

10. 数据类型不匹配

  • 场景: 如果查询中使用的列的数据类型与索引列的数据类型不匹配,可能导致索引失效。
  • 例子:
    SELECT * FROM employees WHERE salary = '30000';
    如果 salaryINT 类型,而查询中使用了字符串类型的 30000,索引可能失效。

11. 使用 JOIN 时连接条件没有使用索引

  • 场景: 当连接条件( ON 子句)没有涉及索引时,索引会失效。
  • 例子:
    SELECT * FROM employees e JOIN departments d ON e.department_id = d.id;
    如果 department_id 没有索引,查询可能会进行全表扫描。

12. 使用 OR 和不等于条件(<>

  • 场景: 使用 OR 连接时,如果条件中有不等于( <>)操作符,索引可能失效。
  • 例子:
    SELECT * FROM employees WHERE department_id = 1 OR department_id <> 2;
    这种情况下,索引可能无法完全利用。

13. 字符串拼接或连接运算

  • 场景: 当查询条件中对列进行拼接或连接运算时,索引会失效。
  • 例子:
    SELECT * FROM employees WHERE CONCAT(first_name, ' ', last_name) = 'John Doe';
    这种字符串连接操作会导致索引无法使用。

14. 隐式类型转换

  • 场景: 如果查询中对列进行隐式类型转换,索引可能无法使用。
  • 例子:
    SELECT * FROM employees WHERE salary = '30000.00';
    如果 salary 列是 FLOAT 类型,而查询使用了字符串 '30000.00',这可能导致隐式类型转换,从而使索引失效。

总结

  • 常见原因: 使用 OR、函数、范围查询、 LIKE 开头、 NOTIS NULLDISTINCT 等。
  • 避免策略: 尽量避免在查询条件中使用这些情况,或者使用合适的索引(如组合索引、覆盖索引)来优化查询。

本文由 mdnice 多平台发布

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/70722.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

06排序 + 查找(D2_查找(D2_刷题练习))

目录 1. 二分查找-I 1.1 题目描述 1.2 解题思路 方法&#xff1a;二分法&#xff08;推荐使用&#xff09; 2. 二维数组中的查找 2.1 题目描述 2.2 解题思路 方法一&#xff1a;二分查找&#xff08;推荐使用&#xff09; 3. 寻找峰值 3.1 题目描述 3.2 解题思路 方…

防火墙综合练习2

准备阶段 实验拓扑图如下&#xff1a; 试验要求如下&#xff1a; 需求一&#xff1a;完成相关配置 需求二&#xff1a;配置DHCP协议 需求三&#xff1a;防火墙安全区域配置 需求四&#xff1a;防火墙地址组信息 需求五&#xff1a;管理员 需求六&#xff1a;用户认证…

Word中Ctrl+V粘贴报错问题

Word中CtrlV粘贴时显示“文件未找到&#xff1a;MathPage.WLL”的问题 Word的功能栏中有MathType&#xff0c;但无法使用&#xff0c;显示灰色。 解决方法如下&#xff1a; 首先找到MathType安装目录下MathPage.wll文件以及MathType Commands 2016.dotm文件&#xff0c;分别复…

什么是FPGA?

目录 一、什么是 FPGA 二、FPGA 的发展历史 三、FPGA 的基本结构 可编程逻辑单元&#xff08;CLB&#xff09; 输入输出块&#xff08;IOB&#xff09; 块随机访问存储器模块&#xff08;BRAM&#xff09; 时钟管理模块&#xff08;CMM&#xff09; 四、FPGA 的工作原理…

ESP8266配置为TCP客户端,连接电脑和手机(使用Arduino配置)

一、简介 基于 ESP8266 的 Arduino 代码&#xff0c;其主要功能是将 ESP8266 连接到指定的 Wi-Fi 网络&#xff0c;并与指定 IP 地址和端口号的服务器建立 TCP 连接。在连接成功后&#xff0c;实现了串口和网络数据的双向传输&#xff0c;也就是将从串口接收到的数据通过 Wi-Fi…

【深度学习】多目标融合算法(四):多门混合专家网络MMOE(Multi-gate Mixture-of-Experts)

目录 一、引言 二、MMoE&#xff08;Multi-gate Mixture-of-Experts&#xff0c;多门混合专家网络&#xff09; 2.1 技术原理 2.2 技术优缺点 2.3 业务代码实践 2.3.1 业务场景与建模 2.3.2 模型代码实现 2.3.3 模型训练与推理测试 2.3.4 打印模型结构 三、总结 一、…

9 数据流图

9 数据流图 9.1数据平衡原则 子图缺少处理后的数据操作结果返回前端应用以及后端数据库返回操作结果到数据管理中间件。 9.2解题技巧 实件名 存储名 加工名 数据流

Hdoop之MapReduce的原理

简单版本 AppMaster: 整个Job任务的核心协调工具 MapTask: 主要用于Map任务的执行 ReduceTask: 主要用于Reduce任务的执行 一个任务提交Job --> AppMaster(项目经理)--> 根据切片的数量统计出需要多少个MapTask任务 --> 向ResourceManager(Yarn平台的老大)索要资源 --…

Linux云计算SRE-第六周

1. 总结openssh服务安全加固和总结openssh免密认证原理&#xff0c;及免认证实现过程。 1、 openssh服务安全加固 OpenSSH&#xff08;Open Secure Shell&#xff09;服务安全加固是确保远程登录会话和其他网络服务安全性的关键步骤。以下是一些常见的OpenSSH服务安全加固措施…

Excel 笔记

实际问题记录 VBA脚本实现特殊的行转列 已知&#xff1a;位于同一Excel工作簿文件中的两个工作表&#xff1a;Sheet1、Sheet2。 问题&#xff1a;现要将Sheet2中的每一行&#xff0c;按Sheet1中的样子进行转置&#xff1a; Sheet2中每一行的黄色单元格&#xff0c;为列头。…

react使用if判断

1、第一种 function Dade(req:any){console.log(req)if(req.data.id 1){return <span>66666</span>}return <span style{{color:"red"}}>8888</span>}2、使用 {win.map((req,index) > ( <> <Dade data{req}/>{req.id 1 ?…

Java从入门到精通 第三版 读书笔记

第一章 初识Java Java同时是编译型(编译器将Java源代码静态编译为Java字节码)和解释型(JVM将Java字节码动态解释为本地机器码)语言。Java程序的运行需要解释器(如JVM)。因Java字节码本具有平台无关性,那么若要在一个新目标平台上运行一个Java程序,则仅需解释器做好目标…

【零基础学习CAPL】——Panel之弹窗的创建与使用

🙋‍♂️【零基础学习CAPL】系列💁‍♂️点击跳转 ——————————————————————————————————–—— 从0开始学习CANoe使用 从0开始学习车载测试 相信时间的力量 星光不负赶路者,时光不负有心人。 文章目录 1.概述2. panel制作2.1 panel窗体…

C# OpenCV机器视觉:对位贴合

在热闹非凡的手机维修街上&#xff0c;阿强开了一家小小的手机贴膜店。每天看着顾客们自己贴膜贴得歪歪扭扭&#xff0c;不是膜的边缘贴不整齐&#xff0c;就是里面充满了气泡&#xff0c;阿强心里就想&#xff1a;“要是我能有个自动贴膜的神器&#xff0c;那该多好啊&#xf…

推荐一个免费的、开源的大数据工程学习教程

在当今信息爆炸的时代&#xff0c;每一个企业都会产生大量的数据&#xff0c;而大数据也已经成为很多企业发展的重要驱动力&#xff0c;然而如何有效得处理和分析这些海量的数据&#xff0c;却是一个非常有挑战的技术。 今天推荐一个免费的数据工程教程&#xff0c;带你系统化…

2月10日QT

作业> 将文本编辑器功能完善 include "widget.h" #include "ui_widget.h" #include <QMessageBox> //消息对话框类 #include <QFontDialog> //字体类对话框 #include <QFont> //字体类 #include <QColorDialog> //颜…

【Java】多线程和高并发编程(四):阻塞队列(上)基础概念、ArrayBlockingQueue

文章目录 四、阻塞队列1、基础概念1.1 生产者消费者概念1.2 JUC阻塞队列的存取方法 2、ArrayBlockingQueue2.1 ArrayBlockingQueue的基本使用2.2 生产者方法实现原理2.2.1 ArrayBlockingQueue的常见属性2.2.2 add方法实现2.2.3 offer方法实现2.2.4 offer(time,unit)方法2.2.5 p…

【Java】多线程和高并发编程(三):锁(下)深入ReentrantReadWriteLock

文章目录 4、深入ReentrantReadWriteLock4.1 为什么要出现读写锁4.2 读写锁的实现原理4.3 写锁分析4.3.1 写锁加锁流程概述4.3.2 写锁加锁源码分析4.3.3 写锁释放锁流程概述&释放锁源码 4.4 读锁分析4.4.1 读锁加锁流程概述4.4.1.1 基础读锁流程4.4.1.2 读锁重入流程4.4.1.…

【R语言】相关系数

一、cor()函数 cor()函数是R语言中用于计算相关系数的函数&#xff0c;相关系数用于衡量两个变量之间的线性关系强度和方向。 常见的相关系数有皮尔逊相关系数&#xff08;Pearson correlation coefficient&#xff09;、斯皮尔曼秩相关系数&#xff08;Spearmans rank corre…

编译和链接【一】

文章目录 编译和链接【一】从翻译单元到二进制文件 编译和链接【一】 在我大一的时候&#xff0c; 我使用VC6.0对C语言程序进行编译链接和运行 &#xff0c; 然后我接触了VS&#xff0c; VS code等众多IDE&#xff0c; 这些IDE界面友好&#xff0c; 使用方便&#xff0c; 例如…