MySQL最左匹配原则
MySQL索引的加左原则,也被称为最左匹配原则(Leftmost Prefix Rule)或最左前缀规则(Leftmost Prefixes),是指在创建复合索引时,应将经常用于查询的列放在索引的最左边,以便MySQL能够更有效地使用该索引来优化查询性能。
为什么要遵循加左原则?
MySQL索引的加左原则(Leftmost Prefix Rule)是由于其B-Tree索引的数据结构和存储方式决定的。
B-Tree索引是一种平衡的多路查找树,它将数据存储在一个有序的结构中,允许快速查找、插入和删除操作。每个叶子节点包含了对应的行数据指针或行数据本身,而非叶子节点则包含了索引值和指向子树的指针。
在复合索引中,MySQL会将多个列的值组合成一个键来进行排序和查找。这个键的排序方式是从左到右的,也就是说,MySQL首先会比较这个复合键的最左边一列,然后是第二列,以此类推。
当MySQL执行一个查询时,它会尝试使用索引来加速查找。它会从索引的最左边开始匹配查询条件,并逐步向右移动。如果查询条件与索引的某一列不匹配,MySQL就无法继续使用该索引来过滤数据了。
以下是几个原因,解释了为什么MySQL索引有加左原则:
数据排序:B-Tree索引是按照复合键的顺序进行排序的,首先是最左边的列。如果你不遵循加左原则,索引的排序方式就与查询条件的顺序不匹配,导致MySQL无法有效地使用索引。
索引范围扫描:当你在WHERE子句中使用范围查询(如WHERE col1 > 10 AND col1 < 20)时,MySQL可以使用索引的最左边一列来确定需要扫描的索引范围。只有当查询条件与索引的最左边一列匹配时,MySQL才可以执行索引范围扫描。
索引选择性:选择性是指索引中不同值的数量与总行数的比率。最左边的列应该是选择性最高的列,这样可以使MySQL更快地排除不符合条件的行。
索引覆盖:如果你的查询只涉及到复合索引中的一部分列,并且这些列正好是最左边的几列,那么MySQL可以直接从索引中获取所需的数据,而不需要回表查找。这种情况被称为“索引覆盖”,可以极大地提高查询效率。
索引合并:在某些情况下,MySQL可能会使用多个索引来优化查询。最左匹配原则可以帮助MySQL更好地选择和合并这些索引。
总之,遵循加左原则可以使MySQL更好地利用B-Tree索引的特性,提高查询效率。然而,索引设计是一个复杂的过程,需要根据具体的查询模式和数据分布来决定最佳的索引策略。
遵循最左匹配原则可以帮助MySQL更有效地使用复合索引来加速查询。以下是几个原因:
减少查找的范围:当MySQL从索引的最左边开始匹配时,它可以快速缩小需要查找的数据范围,从而提高查询速度。
避免全表扫描:如果不遵循最左匹配原则,MySQL可能需要进行全表扫描来找到符合条件的数据,这将大大降低查询性能。
提高索引的选择性:选择性是指索引中不同值的数量与总行数的比率。如果最左边的列有很高的选择性,MySQL可以更准确地估计数据分布,选择更好的执行计划。
举例说明:
假设我们有一个名为users
的表,包含name
、age
和address
三列,并且我们创建了一个复合索引(name, age)
。
-
完全匹配:如果查询语句是
SELECT * FROM users WHERE name = 'John' AND age = 30;
,MySQL会从索引的最左边开始匹配,首先匹配name
列,然后匹配age
列。因为查询条件与索引的最左边两列完全匹配,所以MySQL可以使用整个复合索引来快速定位数据。 -
部分匹配:如果查询语句是
SELECT * FROM users WHERE age = 30 AND name = 'John';
,MySQL仍然会从索引的最左边开始匹配,但它首先尝试匹配age
列,因为age
在索引的最左边。由于age
列不是完全匹配的第一个条件,MySQL只能使用索引的部分(即age
列)来过滤数据,剩余的条件(name = 'John'
)需要在过滤后的结果集中进行额外的检查。 -
不匹配:如果查询语句是
SELECT * FROM users WHERE address = 'New York';
,MySQL无法使用这个复合索引来优化查询,因为address
列不在索引的最左边。
如何应用加左原则?
-
分析查询语句:在创建复合索引之前,仔细分析你的查询语句,确定哪些列经常被用作查询条件。
-
选择正确的顺序:将这些列按照使用频率或选择性从高到低的顺序排列在复合索引中。选择性是指索引中不同值的数量与总行数的比率,选择性越高,索引越有用。
-
避免使用函数或表达式:在索引中使用函数或表达式会使MySQL无法使用索引的最左匹配原则。尽量在查询语句中避免对索引列使用函数或表达式。
-
注意索引类型:不同的索引类型(如B-Tree索引、Hash索引)对最左匹配原则的适用性不同。B-Tree索引是最常用的索引类型,也是唯一支持范围查询的索引类型,适合大多数情况。
-
使用EXPLAIN分析:使用
EXPLAIN
语句来分析你的查询语句,了解MySQL是如何使用索引的。如果发现MySQL不是使用你预期的索引,可能需要重新考虑你的索引策略。
例外情况
使用全文索引:全文索引不遵循最左匹配原则,因为它们是用来支持复杂的文本搜索的。
使用覆盖索引:覆盖索引包含了查询语句所需的所有列,MySQL可以直接从索引中获取数据,而不需要访问表数据。在这种情况下,不需要遵循最左匹配原则。
注意事项
-
不要过度索引:虽然复合索引可以提高查询效率,但过度索引会增加写入操作的开销,并可能导致索引维护的性能问题。
-
适当调整索引顺序:如果你的查询模式发生了变化,可能需要重新评估并调整索引的顺序。
-
考虑使用单列索引:对于某些列,如果它们经常单独用作查询条件,或者作为
WHERE
子句中的第一个条件,可能更适合使用单列索引而不是复合索引。
使得索引失效或效果不佳的情况:
-
没有使用最左边的索引列:如果你的查询条件不包含复合索引的最左边一列,MySQL就不能使用这个索引来过滤数据。例如,假设你有一个复合索引
(col1, col2, col3)
,但你的查询语句是SELECT * FROM table WHERE col2 = 'value2' AND col3 = 'value3';
,那么MySQL可能不会使用这个复合索引。 -
在最左边的索引列上使用不等值条件:如果你在最左边的索引列上使用了不等值条件(如
WHERE col1 > 'value1'
),MySQL可能会选择不使用索引,而进行全表扫描。因为在B-Tree索引中,等值条件可以帮助MySQL快速定位到需要查找的数据范围。 -
在最左边的索引列上使用函数或表达式:如果你在最左边的索引列上使用了函数或表达式(如
WHERE LEFT(col1, 3) = 'abc'
),MySQL也不能使用索引。因为索引是基于原始值建立的,而不是基于函数或表达式的结果。 -
在最左边的索引列上使用LIKE查询且通配符在前面:如果你的LIKE查询的通配符在前面(如
WHERE col1 LIKE '%value1'
),MySQL同样不能使用索引。因为通配符在前面,MySQL无法确定从哪里开始查找。 -
使用OR条件连接索引列:如果你在WHERE子句中使用OR条件来连接不同的索引列(如
WHERE col1 = 'value1' OR col2 = 'value2'
),MySQL可能会选择不使用索引,而进行全表扫描。因为OR条件会扩大查询结果的范围,MySQL很难通过索引来确定哪些行符合条件。 -
索引列的选择性太低:如果最左边的索引列的选择性非常低(即大多数行都有相同的值),那么MySQL可能会选择不使用索引,而直接扫描表数据。
-
索引列顺序与查询条件顺序不一致:如果你的复合索引列的顺序与查询条件的顺序不一致,MySQL可能会选择不使用索引,或者使用索引但效果不佳。例如,假设你有一个复合索引
(col1, col2)
,但你的查询语句是SELECT * FROM table WHERE col2 = 'value2' AND col1 = 'value1';
,那么MySQL可能不会使用这个复合索引。 -
索引列中存在NULL值:如果最左边的索引列中存在NULL值,MySQL可能会选择不使用索引。因为NULL值的存在使得MySQL无法确定索引的顺序和范围。
-
使用了不等于(!=)或NOT IN操作符:这些操作符会使得MySQL无法确定从哪里开始或结束扫描索引,因此可能会选择不使用索引。
以上这些情况都可能导致MySQL索引失效或效果不佳。如果你发现自己的查询语句没有使用到预期的索引,可以使用EXPLAIN语句来分析查询计划,找出原因,并进行相应的优化。记住,索引设计是一个动态的过程,需要根据实际的查询模式和数据分布来调整。
相关文章:
MySQL最左匹配原则
MySQL索引的加左原则,也被称为最左匹配原则(Leftmost Prefix Rule)或最左前缀规则(Leftmost Prefixes),是指在创建复合索引时,应将经常用于查询的列放在索引的最左边,以便MySQL能够更…...

日常开发1:居中处理
开发的时候总会遇到两个空间上下两层,然后居中排放,如果只是知道下方或者上方控件的具体位置点,但是不知道另外一个控件的集体点位,应该怎么处理呢? 如上图所示,知道imageview 下方中间的点的位置(这里暂时定义image的宽高已知),上方是textview,那么如何布局呢? 简单解决方法…...

css弹性盒子——flex布局
目录 编辑 一、flex容器的样式属性(父元素属性) display:flex 弹性盒子,实现水平排列,在父盒子设置,适用于单行/单列 justify-content 二、flex元素的样式属性(子元素属性) 1.flex-grow 2.flex-shrink 3.flex-basis 4.flex组合属性 flex:flex-…...

亚马逊云科技 Gen BI 2024-09-04 上海站QuickSight
机缘 我又来了,感觉不上班比上班还要忙 天天像特种工一天,今天有度过的充实的一天,上午去图书馆,下午去了 亚马逊云科技 Gen BI 技术体验日 。 具体照片可以去 这里看 哈哈,这个就是我了 商业智能的趋势 根据艾瑞咨…...
【Qt】Qt和JavaScript使用QWebChannel交互
问题 问题一: 问题描述:运行时,Qt向Js端发送消息没有问题,Js端向Qt端发送消息时失败 报错:Cannot invoke unknown method of index -1 on object webTransport(0x…) 原因及解决办法:使用Qt 5.11.2编译生…...

码住!15个爆好用知识库软件工具分享
市场趋势:全球知识库管理软件的市场规模发展速度非常快,并且未来几年内仍将继续保持增长。据Verified Market Research预测,2028年知识库管理软件的全球市场份额将增长到588.1亿美元,复合年增长率达12.67%。 知识库软件可以帮助企…...
MybatisPlus中@EnumValue注解介绍、应用场景和示例代码
EnumValue注解详细介绍 功能概述: EnumValue注解标记在枚举类型的字段上,表示该字段是枚举值在数据库中存储的实际值。这对于枚举的持久化是关键,确保枚举在数据库中的表示与Java枚举类的一致性。 主要用途: 字段指定:…...

【计算机网络】描述TCP建立连接与断开的过程
一、TCP连接的建立与断开 1、建立连接——三次握手 1、A的TCP向B发出连接请求报文段 其首部中的同步位SYN 1,并选择序号seq x,表明传送数据时的第一个数据字节的序号是 x 2、B的TCP收到连接请求报文段后,如同意,则发回确认。 B …...
CSS学习14[重点]
定位 前言一、定位二、定位模式1. 静态定位 static2. 相对定位 relative3. 绝对定位 absolute4. 子绝父相5. 绝对定位的盒子水平居中 6. 固定定位(fixed)7. 叠放次序(z)三、四种定位总结四、定位模式转换 前言 为什么学习定位&am…...

力扣 | 递归 | 区间上的动态规划 | 486. 预测赢家
文章目录 一、递归二、区间动态规划 LeetCode:486. 预测赢家 一、递归 注意到本题数据范围为 1 < n < 20 1<n<20 1<n<20,因此可以使用递归枚举选择方式,时间复杂度为 2 20 1024 ∗ 1024 1048576 1.05 1 0 6 2^{20…...
黑白格
题目描述 小杨有一个 n 行 m 列的网格图,其中每个格子要么是白色,要么是黑色。 小杨想知道至少包含 k 个黑色格子的最小子矩形包含了多少个格子。 输入格式 第一行包含三个正整数 n,m,k,含义如题面所示。 之后 n 行,每行⼀个…...

数据链路层(MAC地址)
文章目录 数据链路层(MAC地址)1、以太网2、以太网帧格式3、MAC地址4、对比理解 MAC 地址和 IP 地址5、最大传输单元(MTU)6、MTU 对 IP 协议的影响7、MTU 对 UDP 协议的影响8、MTU 对 TCP 协议的影响9、查看硬件地址和 MTU10、ARP …...
【ruby java】登陆功能/邮件发送模版240903
Rails 风格登录系统添加全面而详细的注释,解释每个部分的功能和用途。 详细注释,解释了每个文件和代码块的功能。以下是一些关键点的总结: 1. 控制器(Controllers): - ApplicationController: …...

告别格式不兼容烦恼!ape转换mp3,分享3个简单方法
各位读者们,你们是否有过这种体验:满怀期待地在网上下载一首好听的歌曲,结果怎么点击手机都播放不了,定睛一看,弹窗显示“无法播放该音频文件”。这是为什么呢?原来那首歌的音频格式是ape,不被手…...

Java核心知识体系-并发与多线程:线程基础
1 先导 Java线程基础主要包含如下知识点,相信我们再面试的过程中,经常会遇到类似的提问。 1、线程有哪几种状态? 线程之间如何转变? 2、线程有哪几种实现方式? 各优缺点? 3、线程的基本操作(线程管理机制ÿ…...

KRaft模式下的Kafka启动指南:摆脱Zookeeper依赖
一、背景介绍 多年来,人们一直在同时使用Apache ZooKeeper和Apache Kafka。但是自Apache Kafka 3.3发布以来,它就可以在没有ZooKeeper的情况下运行。同时它包含了新的命令kafka-metadata-quorum和kafka-metadata-shell?该如何安装新版kafka,…...

【数据库】MySQL-基础篇-函数
专栏文章索引:数据库 有问题可私聊:QQ:3375119339 目录 一、简介 二、字符串函数 三、数值函数 四、日期函数 五、流程函数 一、简介 函数 是指一段可以直接被另一段程序调用的程序或代码。 也就意味着,这一段程序或代码在 M…...

dp练习【4】
最长数对链 646. 最长数对链 给你一个由 n 个数对组成的数对数组 pairs ,其中 pairs[i] [lefti, righti] 且 lefti < righti 。 现在,我们定义一种 跟随 关系,当且仅当 b < c 时,数对 p2 [c, d] 才可以跟在 p1 [a, b…...
php 实现推荐算法
在PHP中实现推荐算法的应用场景通常包括电商、社交媒体、内容平台等。推荐算法可以帮助用户找到与其兴趣相关的内容,提高用户体验和平台黏性。以下是几种常见的推荐算法及其PHP实现方式: 1. 基于协同过滤的推荐算法 协同过滤(Collaborative…...
相机光学(三十六)——光圈
0.参考链接 (1)Hall光圈和Piris光圈的区别 (2)自动光圈及P-IRIS原理 1.光圈分类 Hall光圈和Piris光圈是两种不同的光圈技术。它们之间的区别如下: Hall光圈:Hall光圈是一种传统的光电子元件,通…...

业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
【网络】每天掌握一个Linux命令 - iftop
在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...

C# 类和继承(抽象类)
抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...

04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...
Unit 1 深度强化学习简介
Deep RL Course ——Unit 1 Introduction 从理论和实践层面深入学习深度强化学习。学会使用知名的深度强化学习库,例如 Stable Baselines3、RL Baselines3 Zoo、Sample Factory 和 CleanRL。在独特的环境中训练智能体,比如 SnowballFight、Huggy the Do…...

【JVM面试篇】高频八股汇总——类加载和类加载器
目录 1. 讲一下类加载过程? 2. Java创建对象的过程? 3. 对象的生命周期? 4. 类加载器有哪些? 5. 双亲委派模型的作用(好处)? 6. 讲一下类的加载和双亲委派原则? 7. 双亲委派模…...
如何配置一个sql server使得其它用户可以通过excel odbc获取数据
要让其他用户通过 Excel 使用 ODBC 连接到 SQL Server 获取数据,你需要完成以下配置步骤: ✅ 一、在 SQL Server 端配置(服务器设置) 1. 启用 TCP/IP 协议 打开 “SQL Server 配置管理器”。导航到:SQL Server 网络配…...
【安全篇】金刚不坏之身:整合 Spring Security + JWT 实现无状态认证与授权
摘要 本文是《Spring Boot 实战派》系列的第四篇。我们将直面所有 Web 应用都无法回避的核心问题:安全。文章将详细阐述认证(Authentication) 与授权(Authorization的核心概念,对比传统 Session-Cookie 与现代 JWT(JS…...

【免费数据】2005-2019年我国272个地级市的旅游竞争力多指标数据(33个指标)
旅游业是一个城市的重要产业构成。旅游竞争力是一个城市竞争力的重要构成部分。一个城市的旅游竞争力反映了其在旅游市场竞争中的比较优势。 今日我们分享的是2005-2019年我国272个地级市的旅游竞争力多指标数据!该数据集源自2025年4月发表于《地理学报》的论文成果…...
字符串哈希+KMP
P10468 兔子与兔子 #include<bits/stdc.h> using namespace std; typedef unsigned long long ull; const int N 1000010; ull a[N], pw[N]; int n; ull gethash(int l, int r){return a[r] - a[l - 1] * pw[r - l 1]; } signed main(){ios::sync_with_stdio(false), …...