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光圈是一种传统的光电子元件,通…...
《Playwright:微软的自动化测试工具详解》
Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
Spring Boot面试题精选汇总
🤟致敬读者 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉 📘博主相关 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息 文章目录 Spring Boot面试题精选汇总⚙️ **一、核心概…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
如何理解 IP 数据报中的 TTL?
目录 前言理解 前言 面试灵魂一问:说说对 IP 数据报中 TTL 的理解?我们都知道,IP 数据报由首部和数据两部分组成,首部又分为两部分:固定部分和可变部分,共占 20 字节,而即将讨论的 TTL 就位于首…...
用机器学习破解新能源领域的“弃风”难题
音乐发烧友深有体会,玩音乐的本质就是玩电网。火电声音偏暖,水电偏冷,风电偏空旷。至于太阳能发的电,则略显朦胧和单薄。 不知你是否有感觉,近两年家里的音响声音越来越冷,听起来越来越单薄? —…...
Proxmox Mail Gateway安装指南:从零开始配置高效邮件过滤系统
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「storms…...
Vue 模板语句的数据来源
🧩 Vue 模板语句的数据来源:全方位解析 Vue 模板(<template> 部分)中的表达式、指令绑定(如 v-bind, v-on)和插值({{ }})都在一个特定的作用域内求值。这个作用域由当前 组件…...
Linux中《基础IO》详细介绍
目录 理解"文件"狭义理解广义理解文件操作的归类认知系统角度文件类别 回顾C文件接口打开文件写文件读文件稍作修改,实现简单cat命令 输出信息到显示器,你有哪些方法stdin & stdout & stderr打开文件的方式 系统⽂件I/O⼀种传递标志位…...
Kubernetes 节点自动伸缩(Cluster Autoscaler)原理与实践
在 Kubernetes 集群中,如何在保障应用高可用的同时有效地管理资源,一直是运维人员和开发者关注的重点。随着微服务架构的普及,集群内各个服务的负载波动日趋明显,传统的手动扩缩容方式已无法满足实时性和弹性需求。 Cluster Auto…...
