索引的最左匹配原则全面分析

news2024/12/29 13:23:00

简介

组合索引中的最左优先,以组合索引中最左边的列为起点任何连续的索引都能匹配上。如果遇到范围查询(>、<、between、like)就会停止匹配。

准备

CREATE TABLE `test` (
    `id` bigint(11) NOT NULL,
    `column1` int DEFAULT NULL,
    `column2` int DEFAULT NULL,
    `column3` int DEFAULT NULL,
    `column4` varchar(255) DEFAULT NULL,
    `column5` varchar(255) DEFAULT NULL,
    `column6` varchar(255) DEFAULT NULL,
    `number` int DEFAULT NULL,
    PRIMARY KEY (`id`),
    KEY `idx_column1_2_3` (`column1`,`column2`,`column3`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

id为主键,组合索引idx_column1_2_3包含三个列(column1,column2,column3)

数据

在这里插入图片描述

分析

等值查询

以column1列为最左匹配的查询

1 where条件中根据column1过滤

explain select * from test where column1 = 5

在这里插入图片描述
2 where条件中根据column1、column2过滤

explain select * from test where column1 = 5 and column2 = 5

在这里插入图片描述
3 where条件汇总根据column1、column2、column3过滤

explain select * from test where column1 = 5 and column2 = 5 and column3 = 5

在这里插入图片描述
结论:
可以看到以column1列为最左匹配的查询是可以执行到索引的

不以column1列为最左匹配的查询

1 where条件中根据column2、column1过滤

explain select * from test where column2 = 5 and column1 = 5

在这里插入图片描述
2 where条件中根据column2、column1、column3过滤

explain select * from test where column2 = 5 and column1 = 5 and column3 = 5

在这里插入图片描述
3 where条件中根据column3过滤

explain select * from test where column3 = 5

在这里插入图片描述

4 where条件中根据column3、column1过滤

explain select * from test where column3 = 5 and column1 = 5

在这里插入图片描述
5 where条件中根据column3、column1、column2过滤

explain select * from test where column3 = 5 and column1 = 5 and column2 = 5

在这里插入图片描述
结论

  • 不符合最左匹配原则,只有column2column3为条件的等值查询是不走索引的
  • 只要有column1列存在的情况下,不论column2column3顺序如何,都会走索引的,这是因为mysql会进行优化

不含有column1列的查询

1 where条件中根据column2过滤

explain select * from test where column2 = 5

在这里插入图片描述

2 where条件汇总根据column2过滤,查询column2

explain select column2 from test where column2 = 5

在这里插入图片描述
结论
这个比较特殊,虽然没有column1没有遵循最左匹配原则,但这是索引覆盖类型,也就是能直接就在索引上进行过滤和查询列,不需要回表,所以这种也是可以走索引的。

范围查询

以column1列为最左匹配的查询

1 where条件column1等值查询,column2范围查询

explain select * from test where column1= 5 and column2 >= 5

在这里插入图片描述
2 where条件column1等值查询,column3 范围查询

explain select * from test where column1= 5 and column3 >= 5

在这里插入图片描述
3 where条件中column1等值查询,column2范围查询(范围条件>=),column3范围查询(范围条件>=)

explain select * from test where column1= 5 and column2 >= 5 and column3 >= 5

在这里插入图片描述
结论
可以看到范围条件是>=的,column1column2column3三个列都能用到索引

4 where条件中column1等值查询,column2范围查询(范围条件>),column3范围查询(范围条件>)

explain select * from test where column1= 5 and column2 > 5 and column3 > 5

在这里插入图片描述
结论
可以看到范围条件是>的,column1column2能用到索引,、column3全表扫描

5 where条件中column1范围查询,column2等值查询

explain select * from test where column1 >= 5 and column2 = 5

在这里插入图片描述

不以column1列为最左匹配的查询

1 where条件column2 范围查询、column1范围查询

explain select * from test where column2 >= 5 and column1 >= 5

在这里插入图片描述

2 where条件column2 范围查询、column1等值查询

explain select * from test where column2 >= 5 and column1 = 5

在这里插入图片描述
3 where条件column2范围查询

explain select * from test where column2 > 5

在这里插入图片描述
4 where条件column2范围查询,只查询column2列

explain select column2 from test where column2 > 5

在这里插入图片描述
结论
虽然没有column1没有遵循最左匹配原则,但这是索引覆盖类型,也就是能直接就在索引上进行过滤和查询列,不需要回表,所以这种也是可以走索引的。

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

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

相关文章

振弦采集仪在岩土工程安全监测使用的解决方案

振弦采集仪是一种岩土工程安全监测仪器&#xff0c;主要用于监测建筑物、桥梁、隧道、地铁等工程结构的动态响应&#xff0c;以及岩土体的振动情况。其工作原理是通过振弦传感器采集结构或岩土体的振动信号&#xff0c;再通过数据采集系统进行处理和分析&#xff0c;得出结构或…

一文让你快速写出高效的软件测试用例

前言 编写测试用例的目的就是确保测试过程全面高效、有据可查。但要编写出高效的测试用例&#xff0c;需要搞清楚什么是测试用例&#xff0c;以及如何编写出高效的测试用例&#xff1f;接下来将从以下几个部分来进行展开 1、什么是测试用例 2、如何编写测试用例 3、软件测试学…

element-plus的el-select实现触底加载更多(新版本报错踩坑)

前言 element-plus新版增加了一个属性&#xff0c;且默认为true&#xff0c;使得下拉菜单被插入到了body元素下。即.el-select下默认不包含.el-select-dropdown了。 现象 当依旧按照之前的方式&#xff0c;封装自定义指令&#xff0c;实现滚动到el-select下拉菜单的底部&…

Redis从入门到精通之底层数据结构快表QuickList详解

文章目录 0.前言1. 快表的结构2. Redis 6.0 快表quicklist 基本结构2.1 成员变量2.1 主要操作2.1 推导结果 3. 快表的操作 3. 快表的优缺点3.1 优点&#xff1a;3.2 缺点&#xff1a; 5. Redis从入门到精通系列文章 0.前言 上个篇章回顾&#xff0c;我们上个章节&#xff0c;讲…

计算机中丢失msvcp140.dll的解决方案-由于找不到msvcp140.dll的解决方法

本教程操作系统&#xff1a;电脑 Windows系统、 msvcp140.dll是电脑文件中的dll文件&#xff08;动态链接库文件&#xff09;。如果计算机中丢失了某个dll文件&#xff0c;可能会导致某些软件和游戏等程序无法正常启动运行&#xff0c;并且导致电脑系统弹窗报错。 在我们打开…

STM32串口DMA双缓冲,数据接收与发送,HAL库实现

STM32串口DMA双缓冲 1.简介 STM32F429系列DMA支持双缓冲模式进行数据传输&#xff0c;相当于数字电路设计领域的乒乓操作&#xff0c;但是HAL库并没有实现像单缓冲区一样可以简单使用的函数&#xff0c;有的方法是使用单缓冲的方式&#xff0c;但是通过接收半满的中断控制CPU…

头文件header file和源文件 source file

头文件 header file&#xff0c;后缀是.h&#xff0c;头文件负责类的定义&#xff0c;函数声明&#xff0c;常量的定义 源文件source file&#xff0c;后缀是.cpp&#xff0c; 函数的实现 最主要的作用就是将函数的声明和实现分开&#xff0c;如果想将类和函数交给别人使用&a…

python基本语法知识(五)——面向对象

类和对象 例子1 class Student:name Nonegender Nonenationality Nonenative_place None # 籍贯age None# 类内的成员方法,第一个参数必须为 self,# self相当于是当前对象def say_hi(self):print(f"大家好,我是{self.name}")def say_hi2(self, msg):print(f&q…

自学网络安全怎么规划路线?

01 什么是网络安全 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面…

HuggingFace Bert语言模型抽取句子表征向量

1. 安装相应的包 pip install transformers2. 具体代码 from transformers import BertTokenizer, BertModeltokenizer BertTokenizer.from_pretrained(bert_base_cased, cache_dir"dblp/bert_base_cased", local_files_onlyTrue) model BertModel.from_pretrain…

第七十一天学习记录:对陈正冲编著《C 语言深度解剖》中关于1、2、4,5章作者留下部分问题的学习

问&#xff1a;有如下代码。 static int j;void fun1(void) {static int i 0;i; }void fun2(void) {j 0; j; }int main() {int k 0;for (k 0; k<10; k){fun1();fun2();}return 0; }i 和 j 的值分别是什么,为什么&#xff1f; 答&#xff1a; 在这份代码中&#xff0c;变…

Dtop环球嘉年华推动Web 3.0国际电商领域的革新

随着互联网技术的与日俱进和数字经济的高速发展,国际贸易正在经历一场重大变革。其中,跨境电商作为一种新兴的商业模式,正在全球迅速崛起。然而,自2021年以来,跨境电商行业也面临着各种风险和挑战,如各国增值税新规、电商账号封禁事件以及海运价格持续上涨等冲击。这些因素共同…

Spark SQL数据帧与数据集

文章目录 一、数据帧 - DataFrame&#xff08;一&#xff09;DataFrame概述&#xff08;二&#xff09;将RDD转成DataFrame 二、数据集 - Dataset&#xff08;一&#xff09;Dataset概述&#xff08;二&#xff09;将RDD转成DataSet&#xff08;三&#xff09;DataFrame与Datas…

ATA-4000系列高压功率放大器——超声导波中的典型应用

ATA-4000系列高压功率放大器——超声导波中的典型应用 超声导波技术 超声导波(guided waves ultrasonic)技术是一项近年来广受关注的无损检测技术。导波是由于介质边界存在而被限制在介质中传播的、同时其传播方向平行于介质边界的波。超声导波较早期的研究由一些著名学者完成&…

react + antd实现动态切换主题功能(适用于antd5.x版本)

前言 在之前的几篇文章中&#xff08;React Antd实现动态切换主题功能之二&#xff08;默认主题与暗黑色主题切换&#xff09;、React Antd实现动态切换主题功能&#xff09;介绍了antd实现动态切换主题功能&#xff0c;文章里介绍的方法在antd5.x版本却不适用&#xff0c;因…

【UE5】分分钟简单使用像素流云服务(Pixel Streaming)

【UE5】分分钟简单使用像素流云服务&#xff08;Pixel Streaming&#xff09; 前言 UE5的Pixel Streaming已经封装的很好&#xff0c;简单三步实现简单的服务搭建。 安装插件打包项目运行服务 注&#xff1a;实例平台为Windows 安装插件 编辑→插件→输入查询Pixel Strea…

Java之~Bigdicmal的长度,小数点后用0补位

/*** 获取bigdicmal的长度* param number 需要截取的数字* param num 需要保留小数点后的位数* return*/ public static int checkBigDecimalLength(String number ,int num){String s getSupString(number,num);return s.length(); }/*** 补充后面数值0* param number 需要截…

5G技术学习——5GNR帧结构和空口资源

这里写目录标题 4G时域定义&#xff1a;资源划分 5GNR中时域 频域 与空域资源 循环前缀CP:背景和原理5G帧结构&#xff1a;基本框架5G slot分类 5G 频域资源5G频域资源基本概念信道带宽与传输带宽BWP定义及其应用场景 4G 时域定义&#xff1a; 帧&#xff1a;10ms&#xff0c;…

【go-zero】go-zero微服务实战系列九 聚合策略 极致优化秒杀性能(转)

上一篇文章中引入了消息队列对秒杀流量做削峰的处理,我们使用的是Kafka,看起来似乎工作的不错,但其实还是有很多隐患存在,如果这些隐患不优化处理掉,那么秒杀抢购活动开始后可能会出现消息堆积、消费延迟、数据不一致、甚至服务崩溃等问题,那么后果可想而知。本篇文章我们…

深度学习-pytorch_lightning框架使用实例

下面是我写过的一个pytorch_lightning项目的代码框架。关键代码已经省略。 模型构建 import pytorch_lightning as pl from pytorch_lightning.plugins.io import TorchCheckpointIO as tcio import torch from torch import nn import torch.nn.functional as F from torch.…