当前位置: 首页 > news >正文

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的表,包含nameageaddress三列,并且我们创建了一个复合索引(name, age)

  1. 完全匹配:如果查询语句是SELECT * FROM users WHERE name = 'John' AND age = 30;,MySQL会从索引的最左边开始匹配,首先匹配name列,然后匹配age列。因为查询条件与索引的最左边两列完全匹配,所以MySQL可以使用整个复合索引来快速定位数据。

  2. 部分匹配:如果查询语句是SELECT * FROM users WHERE age = 30 AND name = 'John';,MySQL仍然会从索引的最左边开始匹配,但它首先尝试匹配age列,因为age在索引的最左边。由于age列不是完全匹配的第一个条件,MySQL只能使用索引的部分(即age列)来过滤数据,剩余的条件(name = 'John')需要在过滤后的结果集中进行额外的检查。

  3. 不匹配:如果查询语句是SELECT * FROM users WHERE address = 'New York';,MySQL无法使用这个复合索引来优化查询,因为address列不在索引的最左边。

如何应用加左原则?

  1. 分析查询语句:在创建复合索引之前,仔细分析你的查询语句,确定哪些列经常被用作查询条件。

  2. 选择正确的顺序:将这些列按照使用频率或选择性从高到低的顺序排列在复合索引中。选择性是指索引中不同值的数量与总行数的比率,选择性越高,索引越有用。

  3. 避免使用函数或表达式:在索引中使用函数或表达式会使MySQL无法使用索引的最左匹配原则。尽量在查询语句中避免对索引列使用函数或表达式。

  4. 注意索引类型:不同的索引类型(如B-Tree索引、Hash索引)对最左匹配原则的适用性不同。B-Tree索引是最常用的索引类型,也是唯一支持范围查询的索引类型,适合大多数情况。

  5. 使用EXPLAIN分析:使用EXPLAIN语句来分析你的查询语句,了解MySQL是如何使用索引的。如果发现MySQL不是使用你预期的索引,可能需要重新考虑你的索引策略。

例外情况

使用全文索引:全文索引不遵循最左匹配原则,因为它们是用来支持复杂的文本搜索的。

使用覆盖索引:覆盖索引包含了查询语句所需的所有列,MySQL可以直接从索引中获取数据,而不需要访问表数据。在这种情况下,不需要遵循最左匹配原则。

注意事项

  1. 不要过度索引:虽然复合索引可以提高查询效率,但过度索引会增加写入操作的开销,并可能导致索引维护的性能问题。

  2. 适当调整索引顺序:如果你的查询模式发生了变化,可能需要重新评估并调整索引的顺序。

  3. 考虑使用单列索引:对于某些列,如果它们经常单独用作查询条件,或者作为WHERE子句中的第一个条件,可能更适合使用单列索引而不是复合索引。

使得索引失效或效果不佳的情况:

  1. 没有使用最左边的索引列:如果你的查询条件不包含复合索引的最左边一列,MySQL就不能使用这个索引来过滤数据。例如,假设你有一个复合索引(col1, col2, col3),但你的查询语句是SELECT * FROM table WHERE col2 = 'value2' AND col3 = 'value3';,那么MySQL可能不会使用这个复合索引。

  2. 在最左边的索引列上使用不等值条件:如果你在最左边的索引列上使用了不等值条件(如WHERE col1 > 'value1'),MySQL可能会选择不使用索引,而进行全表扫描。因为在B-Tree索引中,等值条件可以帮助MySQL快速定位到需要查找的数据范围。

  3. 在最左边的索引列上使用函数或表达式:如果你在最左边的索引列上使用了函数或表达式(如WHERE LEFT(col1, 3) = 'abc'),MySQL也不能使用索引。因为索引是基于原始值建立的,而不是基于函数或表达式的结果。

  4. 在最左边的索引列上使用LIKE查询且通配符在前面:如果你的LIKE查询的通配符在前面(如WHERE col1 LIKE '%value1'),MySQL同样不能使用索引。因为通配符在前面,MySQL无法确定从哪里开始查找。

  5. 使用OR条件连接索引列:如果你在WHERE子句中使用OR条件来连接不同的索引列(如WHERE col1 = 'value1' OR col2 = 'value2'),MySQL可能会选择不使用索引,而进行全表扫描。因为OR条件会扩大查询结果的范围,MySQL很难通过索引来确定哪些行符合条件。

  6. 索引列的选择性太低:如果最左边的索引列的选择性非常低(即大多数行都有相同的值),那么MySQL可能会选择不使用索引,而直接扫描表数据。

  7. 索引列顺序与查询条件顺序不一致:如果你的复合索引列的顺序与查询条件的顺序不一致,MySQL可能会选择不使用索引,或者使用索引但效果不佳。例如,假设你有一个复合索引(col1, col2),但你的查询语句是SELECT * FROM table WHERE col2 = 'value2' AND col1 = 'value1';,那么MySQL可能不会使用这个复合索引。

  8. 索引列中存在NULL值:如果最左边的索引列中存在NULL值,MySQL可能会选择不使用索引。因为NULL值的存在使得MySQL无法确定索引的顺序和范围。

  9. 使用了不等于(!=)或NOT IN操作符:这些操作符会使得MySQL无法确定从哪里开始或结束扫描索引,因此可能会选择不使用索引。

以上这些情况都可能导致MySQL索引失效或效果不佳。如果你发现自己的查询语句没有使用到预期的索引,可以使用EXPLAIN语句来分析查询计划,找出原因,并进行相应的优化。记住,索引设计是一个动态的过程,需要根据实际的查询模式和数据分布来调整。

相关文章:

MySQL最左匹配原则

MySQL索引的加左原则&#xff0c;也被称为最左匹配原则&#xff08;Leftmost Prefix Rule&#xff09;或最左前缀规则&#xff08;Leftmost Prefixes&#xff09;&#xff0c;是指在创建复合索引时&#xff0c;应将经常用于查询的列放在索引的最左边&#xff0c;以便MySQL能够更…...

日常开发1:居中处理

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

css弹性盒子——flex布局

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

亚马逊云科技 Gen BI 2024-09-04 上海站QuickSight

机缘 我又来了&#xff0c;感觉不上班比上班还要忙 天天像特种工一天&#xff0c;今天有度过的充实的一天&#xff0c;上午去图书馆&#xff0c;下午去了 亚马逊云科技 Gen BI 技术体验日 。 具体照片可以去 这里看 哈哈&#xff0c;这个就是我了 商业智能的趋势 根据艾瑞咨…...

【Qt】Qt和JavaScript使用QWebChannel交互

问题 问题一&#xff1a; 问题描述&#xff1a;运行时&#xff0c;Qt向Js端发送消息没有问题&#xff0c;Js端向Qt端发送消息时失败 报错&#xff1a;Cannot invoke unknown method of index -1 on object webTransport(0x…) 原因及解决办法&#xff1a;使用Qt 5.11.2编译生…...

码住!15个爆好用知识库软件工具分享

市场趋势&#xff1a;全球知识库管理软件的市场规模发展速度非常快&#xff0c;并且未来几年内仍将继续保持增长。据Verified Market Research预测&#xff0c;2028年知识库管理软件的全球市场份额将增长到588.1亿美元&#xff0c;复合年增长率达12.67%。 知识库软件可以帮助企…...

MybatisPlus中@EnumValue注解介绍、应用场景和示例代码

EnumValue注解详细介绍 功能概述&#xff1a; EnumValue注解标记在枚举类型的字段上&#xff0c;表示该字段是枚举值在数据库中存储的实际值。这对于枚举的持久化是关键&#xff0c;确保枚举在数据库中的表示与Java枚举类的一致性。 主要用途&#xff1a; 字段指定&#xff1a;…...

【计算机网络】描述TCP建立连接与断开的过程

一、TCP连接的建立与断开 1、建立连接——三次握手 1、A的TCP向B发出连接请求报文段 其首部中的同步位SYN 1&#xff0c;并选择序号seq x&#xff0c;表明传送数据时的第一个数据字节的序号是 x 2、B的TCP收到连接请求报文段后&#xff0c;如同意&#xff0c;则发回确认。 B …...

CSS学习14[重点]

定位 前言一、定位二、定位模式1. 静态定位 static2. 相对定位 relative3. 绝对定位 absolute4. 子绝父相5. 绝对定位的盒子水平居中 6. 固定定位&#xff08;fixed&#xff09;7. 叠放次序&#xff08;z&#xff09;三、四种定位总结四、定位模式转换 前言 为什么学习定位&am…...

力扣 | 递归 | 区间上的动态规划 | 486. 预测赢家

文章目录 一、递归二、区间动态规划 LeetCode&#xff1a;486. 预测赢家 一、递归 注意到本题数据范围为 1 < n < 20 1<n<20 1<n<20&#xff0c;因此可以使用递归枚举选择方式&#xff0c;时间复杂度为 2 20 1024 ∗ 1024 1048576 1.05 1 0 6 2^{20…...

黑白格

题目描述 小杨有一个 n 行 m 列的网格图&#xff0c;其中每个格子要么是白色&#xff0c;要么是黑色。 小杨想知道至少包含 k 个黑色格子的最小子矩形包含了多少个格子。 输入格式 第一行包含三个正整数 n,m,k&#xff0c;含义如题面所示。 之后 n 行&#xff0c;每行⼀个…...

数据链路层(MAC地址)

文章目录 数据链路层&#xff08;MAC地址&#xff09;1、以太网2、以太网帧格式3、MAC地址4、对比理解 MAC 地址和 IP 地址5、最大传输单元&#xff08;MTU&#xff09;6、MTU 对 IP 协议的影响7、MTU 对 UDP 协议的影响8、MTU 对 TCP 协议的影响9、查看硬件地址和 MTU10、ARP …...

【ruby java】登陆功能/邮件发送模版240903

Rails 风格登录系统添加全面而详细的注释&#xff0c;解释每个部分的功能和用途。​​​​​​​​​ 详细注释&#xff0c;解释了每个文件和代码块的功能。以下是一些关键点的总结&#xff1a; 1. 控制器&#xff08;Controllers&#xff09;: - ApplicationController: …...

告别格式不兼容烦恼!ape转换mp3,分享3个简单方法

各位读者们&#xff0c;你们是否有过这种体验&#xff1a;满怀期待地在网上下载一首好听的歌曲&#xff0c;结果怎么点击手机都播放不了&#xff0c;定睛一看&#xff0c;弹窗显示“无法播放该音频文件”。这是为什么呢&#xff1f;原来那首歌的音频格式是ape&#xff0c;不被手…...

Java核心知识体系-并发与多线程:线程基础

1 先导 Java线程基础主要包含如下知识点&#xff0c;相信我们再面试的过程中&#xff0c;经常会遇到类似的提问。 1、线程有哪几种状态? 线程之间如何转变&#xff1f; 2、线程有哪几种实现方式? 各优缺点&#xff1f; 3、线程的基本操作&#xff08;线程管理机制&#xff…...

KRaft模式下的Kafka启动指南:摆脱Zookeeper依赖

一、背景介绍 多年来&#xff0c;人们一直在同时使用Apache ZooKeeper和Apache Kafka。但是自Apache Kafka 3.3发布以来&#xff0c;它就可以在没有ZooKeeper的情况下运行。同时它包含了新的命令kafka-metadata-quorum和kafka-metadata-shell?该如何安装新版kafka&#xff0c…...

【数据库】MySQL-基础篇-函数

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

dp练习【4】

最长数对链 646. 最长数对链 给你一个由 n 个数对组成的数对数组 pairs &#xff0c;其中 pairs[i] [lefti, righti] 且 lefti < righti 。 现在&#xff0c;我们定义一种 跟随 关系&#xff0c;当且仅当 b < c 时&#xff0c;数对 p2 [c, d] 才可以跟在 p1 [a, b…...

php 实现推荐算法

在PHP中实现推荐算法的应用场景通常包括电商、社交媒体、内容平台等。推荐算法可以帮助用户找到与其兴趣相关的内容&#xff0c;提高用户体验和平台黏性。以下是几种常见的推荐算法及其PHP实现方式&#xff1a; 1. 基于协同过滤的推荐算法 协同过滤&#xff08;Collaborative…...

相机光学(三十六)——光圈

0.参考链接 &#xff08;1&#xff09;Hall光圈和Piris光圈的区别 &#xff08;2&#xff09;自动光圈及P-IRIS原理 1.光圈分类 Hall光圈和Piris光圈是两种不同的光圈技术。它们之间的区别如下&#xff1a; Hall光圈&#xff1a;Hall光圈是一种传统的光电子元件&#xff0c;通…...

在Ubuntu24上采用Wine打开SourceInsight

1. 安装wine sudo apt install wine 2. 安装32位库支持,SourceInsight是32位程序 sudo dpkg --add-architecture i386 sudo apt update sudo apt install wine32:i386 3. 验证安装 wine --version 4. 安装必要的字体和库(解决显示问题) sudo apt install fonts-wqy…...

代码随想录刷题day30

1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币&#xff0c;另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额&#xff0c;返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...

MySQL 知识小结(一)

一、my.cnf配置详解 我们知道安装MySQL有两种方式来安装咱们的MySQL数据库&#xff0c;分别是二进制安装编译数据库或者使用三方yum来进行安装,第三方yum的安装相对于二进制压缩包的安装更快捷&#xff0c;但是文件存放起来数据比较冗余&#xff0c;用二进制能够更好管理咱们M…...

站群服务器的应用场景都有哪些?

站群服务器主要是为了多个网站的托管和管理所设计的&#xff0c;可以通过集中管理和高效资源的分配&#xff0c;来支持多个独立的网站同时运行&#xff0c;让每一个网站都可以分配到独立的IP地址&#xff0c;避免出现IP关联的风险&#xff0c;用户还可以通过控制面板进行管理功…...

DBLP数据库是什么?

DBLP&#xff08;Digital Bibliography & Library Project&#xff09;Computer Science Bibliography是全球著名的计算机科学出版物的开放书目数据库。DBLP所收录的期刊和会议论文质量较高&#xff0c;数据库文献更新速度很快&#xff0c;很好地反映了国际计算机科学学术研…...

内窥镜检查中基于提示的息肉分割|文献速递-深度学习医疗AI最新文献

Title 题目 Prompt-based polyp segmentation during endoscopy 内窥镜检查中基于提示的息肉分割 01 文献速递介绍 以下是对这段英文内容的中文翻译&#xff1a; ### 胃肠道癌症的发病率呈上升趋势&#xff0c;且有年轻化倾向&#xff08;Bray等人&#xff0c;2018&#x…...

Django RBAC项目后端实战 - 03 DRF权限控制实现

项目背景 在上一篇文章中&#xff0c;我们完成了JWT认证系统的集成。本篇文章将实现基于Redis的RBAC权限控制系统&#xff0c;为系统提供细粒度的权限控制。 开发目标 实现基于Redis的权限缓存机制开发DRF权限控制类实现权限管理API配置权限白名单 前置配置 在开始开发权限…...

【java】【服务器】线程上下文丢失 是指什么

目录 ■前言 ■正文开始 线程上下文的核心组成部分 为什么会出现上下文丢失&#xff1f; 直观示例说明 为什么上下文如此重要&#xff1f; 解决上下文丢失的关键 总结 ■如果我想在servlet中使用线程&#xff0c;代码应该如何实现 推荐方案&#xff1a;使用 ManagedE…...

python可视化:俄乌战争时间线关键节点与深层原因

俄乌战争时间线可视化分析&#xff1a;关键节点与深层原因 俄乌战争是21世纪欧洲最具影响力的地缘政治冲突之一&#xff0c;自2022年2月爆发以来已持续超过3年。 本文将通过Python可视化工具&#xff0c;系统分析这场战争的时间线、关键节点及其背后的深层原因&#xff0c;全面…...

2025 后端自学UNIAPP【项目实战:旅游项目】7、景点详情页面【完结】

1、获取景点详情的请求【my_api.js】 // 引入公共的请求封装 import http from ./my_http.js// 登录接口&#xff08;适配服务端返回 Token&#xff09; export const login async (code, avatar) > {const res await http(/login/getWXSessionKey, {code,avatar}); };//…...