MySQL中的索引失效情况介绍
MySQL中的索引是提高查询性能的重要工具。然而,在某些情况下,索引可能无法发挥作用,甚至导致查询性能下降。在本教程中,我们将探讨MySQL中常见的索引失效情况,以及它们的特点和简单的例子。
1. **索引失效的情况**
**索引列参与计算**
当查询中的索引列参与了计算或函数时,索引将失效。例如,如果查询包含`YEAR(date_column)`函数,则无法使用`date_column`上的索引。
**例子**:
SELECT * FROM orders WHERE YEAR(order_date) = 2021;
在这个例子中,索引`order_date`不会被使用,因为`YEAR`函数已经对日期列进行了计算。
1.2 **索引列排序与查询列顺序不一致**
当查询中的列顺序与索引列的顺序不一致时,索引可能不会被使用。MySQL优化器可能会决定使用全表扫描而不是索引扫描。
**例子**:
SELECT order_date, customer_id FROM orders WHERE customer_id = 123;
在这个例子中,索引`idx_customer_id`(包含`customer_id`和`order_date`)不会被使用,因为查询列的顺序与索引列的顺序不一致。
1.3 **使用不等操作符(<>、!=、<、>、<=、>=)**
当查询使用不等操作符时,索引可能不会被使用。特别是当查询条件包含多个不等操作符时,索引的使用可能性更小。
**例子**:
SELECT * FROM orders WHERE customer_id <> 123 AND order_date > '2021-01-01';
在这个例子中,由于查询条件包含多个不等操作符,索引`idx_customer_id`和`idx_order_date`可能不会被使用。
1.4 **使用OR操作符**
当查询条件包含OR操作符时,索引的使用取决于查询中使用的列是否都包含在索引中。如果查询中的列都包含在索引中,索引可能仍然会被使用。
**例子**:
SELECT * FROM orders WHERE customer_id = 123 OR order_date > '2021-01-01';
在这个例子中,如果索引`idx_customer_id`和`idx_order_date`都包含在索引中,则索引可能会被使用。
1.5 **使用LIKE操作符**
当查询使用LIKE操作符时,索引的使用取决于LIKE操作符的位置和模式。如果LIKE操作符位于查询的开始位置,则索引不会被使用。
**例子**:
SELECT * FROM orders WHERE order_date LIKE '2021%';
在这个例子中,由于LIKE操作符位于查询的开始位置,索引`idx_order_date`不会被使用。
1.6 **使用覆盖索引**
覆盖索引是指查询只需要从索引中获取数据,而不需要读取实际的行数据。如果查询无法完全从索引中获取所需数据,则覆盖索引将失效。
**例子**:
SELECT customer_id FROM orders WHERE order_date > '2021-01-01';
在这个例子中,虽然查询只需要`customer_id`列,但由于查询条件`order_date`不在索引列中,因此无法使用覆盖索引。
1.7 **索引列类型与查询条件类型不匹配**
当索引列的数据类型与查询条件的数据类型不匹配时,索引可能不会被使用。
**例子**:
SELECT * FROM orders WHERE VARCHAR_FORMAT(order_date, '%Y') = '2021';
在这个例子中,由于`VARCHAR_FORMAT`函数改变了索引列`order_date`的数据类型,索引将不会被使用。
1.8 **索引列被覆盖**
当查询中的列完全包含在另一个索引列中时,索引可能不会被使用。
**例子**:
SELECT customer_id, order_date FROM orders WHERE customer_id = 123;
在这个例子中,索引`idx_customer_id`不会被使用,因为查询中的`customer_id`和`order_date`列都包含在索引`idx_customer_id`中,且查询只使用了`customer_id`列。
1.9 **使用非等价条件**
当查询中的条件不是精确匹配(即不是=、IN、<=>)时,索引可能不会被使用。
**例子**:
SELECT * FROM orders WHERE customer_id BETWEEN 123 AND 456;
在这个例子中,由于使用了`BETWEEN`条件,索引`idx_customer_id`可能不会被使用。
1.10 **索引选择性低**
当索引的选择性低时,即索引包含大量重复的值,索引可能不会被使用。
**例子**:
SELECT * FROM orders WHERE customer_id = 1;
在这个例子中,如果`customer_id`列有大量的重复值,索引`idx_customer_id`可能不会被使用。
1.11 **索引无法覆盖查询的所有列**
当查询需要的数据无法完全从索引中获取时,索引可能不会被使用。
**例子**:
SELECT order_date, customer_id FROM orders WHERE customer_id = 123;
在这个例子中,索引`idx_customer_id`(只包含`customer_id`)无法覆盖查询中的`order_date`列,因此索引可能不会被使用。
1.12 **使用不等操作符与函数结合**
当查询中的不等操作符与函数结合使用时,索引可能不会被使用。
**例子**:
SELECT * FROM orders WHERE HOUR(order_date) < 12;
在这个例子中,由于使用了`HOUR`函数与不等操作符结合,索引`idx_order_date`可能不会被使用。
1.13 **使用聚合函数**
当查询中使用了聚合函数时,索引可能不会被使用。
**例子**:
SELECT COUNT(*) FROM orders WHERE customer_id = 123;
在这个例子中,由于使用了`COUNT`聚合函数,索引`idx_customer_id`可能不会被使用。
1.14 **使用GROUP BY或DISTINCT**
当查询中使用了GROUP BY或DISTINCT操作符时,索引可能不会被使用。
**例子**:
SELECT DISTINCT customer_id FROM orders;
在这个例子中,由于使用了`DISTINCT`操作符,索引`idx_customer_id`可能不会被使用。
1.15 **使用子查询**
当查询中使用了子查询时,索引的使用取决于子查询的执行方式和数据来源。
**例子**:
SELECT * FROM orders WHERE customer_id IN (SELECT customer_id FROM customers WHERE name = 'John');
在这个例子中,如果子查询的结果集较大,索引`idx_customer_id`可能不会被使用。
2. **总结**
MySQL中的索引失效情况有很多种,以上只是列举了一些常见的情况。了解这些情况可以帮助我们更好地理解和优化查询性能。在实际应用中,我们需要根据具体情况进行分析和调整,以充分发挥索引的优势。同时,也要注意避免索引失效的情况,提高查询效率。
相关文章:

MySQL中的索引失效情况介绍
MySQL中的索引是提高查询性能的重要工具。然而,在某些情况下,索引可能无法发挥作用,甚至导致查询性能下降。在本教程中,我们将探讨MySQL中常见的索引失效情况,以及它们的特点和简单的例子。 1. **索引失效的情况** …...

SpringBoot异常:类文件具有错误的版本 61.0, 应为 52.0的解决办法
问题: java: 无法访问org.mybatis.spring.annotation.MapperScan 错误的类文件: /D:/Program Files/apache-maven-3.6.0/repository/org/mybatis/mybatis-spring/3.0.3/mybatis-spring-3.0.3.jar!/org/mybatis/spring/annotation/MapperScan.class 类文件具有错误的…...

Cloudways搭建WordPress外贸独立站完整教程
现在做个网站不比从前了,搭建网站非常的简单,主要是由于开源的CMS建站系统的崛起,就算不懂编程写代码的人也能搭建一个自己的网站,这些CMS系统提供了丰富的主题模板和插件,使用户可以通过简单的拖放和配置操作来建立自…...

关于 闰年 的小知识,为什么这样判断闰年
闰年的规定: 知道了由来,我们就可以写程序来判断: #include <stdio.h> int main() {int year, leap;scanf("%d",&year);if((year%4 0 && year%100 ! 0) || year%400 0)leap 1;else leap 0;if(leap) printf(…...

Elasticsearch:调整近似 kNN 搜索
在我之前的文章 “Elasticsearch:调整搜索速度”,我详细地描述了如何调整正常的 BM25 的搜索速度。在今天的文章里,我们来进一步探讨如何提高近似 kNN 的搜索速度。希望对广大的向量搜索开发者有一些启示。 Elasticsearch 支持近似 k 最近邻…...

UE5数字孪生系列笔记(二)
智慧城市数字孪生系统 制作流云动画效果 首先添加一个图像在需要添加流云效果的位置 添加动画效果让其旋转 这个动画效果是程序开始就要进行的,所以要在EventConstruct中就可以启动这个动画效果 添加一个一样的图像在这里,效果是从此处进行放大消散 添…...

基于vue实现bilibili网页
学校要求的实验设计,基于vue实现bilibili网页版,可实现以下功能 (1)基本的悬浮动画和页面渲染 (2)可实现登录和未登录的页面变化 (3)在登录页面的,实现密码判断,或者短信验证方式的倒数功能 (4)实现轮播图 (5)实现预览视频(GIF) (6)页面下拉到一定高度出现top栏以及右下角的返回…...

计算机二级(Python)真题讲解每日一题:《十字叉》
描述 …...

基于正点原子潘多拉STM32L496开发板的简易示波器
一、前言 由于需要对ADC采样性能的评估,重点在于对原波形的拟合性能。 考虑到数据的直观性,本来计划采集后使用串口导出,并用图形做数据拟合,但是这样做的效率低下,不符合实时观察的需要,于是将开发板的屏幕…...
【Docker】apisix 容器化部署
APISIX环境标准软件基于Bitnami apisix 构建。当前版本为3.8.0 你可以通过轻云UC部署工具直接安装部署,也可以手动按如下文档操作,该项目已经全面开源,可以从如下环境获取 配置文件地址: https://gitee.com/qingplus/qingcloud-platform qi…...

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的障碍物检测系统(深度学习代码+UI界面+训练数据集)
摘要:开发障碍物检测系统对于道路安全性具有关键作用。本篇博客详细介绍了如何运用深度学习构建一个障碍物检测系统,并提供了完整的实现代码。该系统基于强大的YOLOv8算法,并对比了YOLOv7、YOLOv6、YOLOv5,展示了不同模型间的性能…...
从零开始学HCIA之SDN04
1、VXLAN数据封装 (1)Original L2 Frame,原始以太网报文,业务应用的以太网帧。 (2)VXLAN Header,VXLAN协议新定义的VXLAN头,长度为8字节。VXLAN ID(VNI)为2…...
GET 和 POST 有什么区别?
1.从缓存的角度,GET 请求会被浏览器主动缓存下来,留下历史记录,而 POST 默认不会。 2.从编码的角度,GET 只能进行 URL 编码,只能接收 ASCII 字符,而 POST 没有限制。 3.从参数的角度,GET 一般放…...

Qt学习--继承(并以分文件实现)
基类 & 派生类 一个类可以派生自多个类,这意味着,它可以从多个基类继承数据和函数。定义一个派生类,我们使用一个类派生列表来指定基类。类派生列表以一个或多个基类命名。 总结:简单来说,父类有的,子…...

软考75-上午题-【面向对象技术3-设计模式】-设计模式的要素
一、题型概括 上午、下午题(试题五、试题六,二选一) 每一个设计模式都有一个对应的类图。 二、23种设计模式 创建型设计模式:5 结构型设计模式:7 行为设计模式:11 考试考1-2种。 三、设计模式的要素 3…...

Matlab|面向低碳经济运行目标的多微网能量互联优化调度
目录 主要内容 优化流程 部分程序 结果一览 下载链接 主要内容 该程序为多微网协同优化调度模型,系统在保障综合效益的基础上,调度时优先协调微网与微网之间的能量流动,将与大电网的互联交互作为备用,降低微网与大电…...

3.Gen<I>Cam文件配置
Gen<I>Cam踩坑指南 我使用的是大恒usb相机,第一步到其官网下载大恒软件安装包,安装完成后图标如图所示,之后连接相机,打开软件,相机显示一切正常。之后查看软件的安装目录如图,发现有GenICam和GenTL两个文件&am…...
【兆易创新GD32H759I-EVAL开发板】 TLI(TFT LCD Interface)用法详细介绍
大纲 1. 引言 2. TLI外设特点 3. TLI硬件架构 4. TLI寄存器功能 5. TLI的配置和使用步骤 6. TLI图层概念 7. 图像处理和显示优化 8. 基于GD32H759I-EVAL开发板的TLI应用示例 1. 引言 在当今的嵌入式系统设计中,图形用户界面(GUI)的应…...

恒创科技:什么是BGP线路服务器?BGP机房的优点是什么?
在当今的互联网架构中,BGP(边界网关协议)线路服务器和BGP机房扮演着至关重要的角色。BGP作为一种用于在自治系统(AS)之间交换路由信息的路径向量协议,它确保了互联网上的数据能够高效、准确地从一个地方传输到另一个地方。那么,究竟什么是BGP…...

苍穹外卖-day04:项目实战-套餐管理(新增套餐,分页查询套餐,删除套餐,修改套餐,起售停售套餐)业务类似于菜品模块
苍穹外卖-day04 课程内容 新增套餐套餐分页查询删除套餐修改套餐起售停售套餐 要求: 根据产品原型进行需求分析,分析出业务规则设计接口梳理表之间的关系(分类表、菜品表、套餐表、口味表、套餐菜品关系表)根据接口设计进行代…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...

Unity3D中Gfx.WaitForPresent优化方案
前言 在Unity中,Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染(即CPU被阻塞),这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案: 对惹,这里有一个游戏开发交流小组&…...

CentOS下的分布式内存计算Spark环境部署
一、Spark 核心架构与应用场景 1.1 分布式计算引擎的核心优势 Spark 是基于内存的分布式计算框架,相比 MapReduce 具有以下核心优势: 内存计算:数据可常驻内存,迭代计算性能提升 10-100 倍(文档段落:3-79…...

什么是库存周转?如何用进销存系统提高库存周转率?
你可能听说过这样一句话: “利润不是赚出来的,是管出来的。” 尤其是在制造业、批发零售、电商这类“货堆成山”的行业,很多企业看着销售不错,账上却没钱、利润也不见了,一翻库存才发现: 一堆卖不动的旧货…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)
引言:为什么 Eureka 依然是存量系统的核心? 尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...
vue3 定时器-定义全局方法 vue+ts
1.创建ts文件 路径:src/utils/timer.ts 完整代码: import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...
Matlab | matlab常用命令总结
常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...

学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2
每日一言 今天的每一份坚持,都是在为未来积攒底气。 案例:OLED显示一个A 这边观察到一个点,怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 : 如果代码里信号切换太快(比如 SDA 刚变,SCL 立刻变&#…...

JVM虚拟机:内存结构、垃圾回收、性能优化
1、JVM虚拟机的简介 Java 虚拟机(Java Virtual Machine 简称:JVM)是运行所有 Java 程序的抽象计算机,是 Java 语言的运行环境,实现了 Java 程序的跨平台特性。JVM 屏蔽了与具体操作系统平台相关的信息,使得 Java 程序只需生成在 JVM 上运行的目标代码(字节码),就可以…...