您当前的位置:首页 > 电脑百科 > 程序开发 > 算法

教您彻底理解索引的最左匹配原则!

时间:2023-11-07 14:36:45  来源:今日头条  作者:测试开发Kevin

最左匹配原则的定义

简单来讲:在联合索引中,只有左边的字段被用到,右边的才能够被使用到。我们在建联合索引的时候,区分度最高的在最左边。

简单的例子

创建一个表

CREATE TABLE `user` (
`id` INT NOT NULL AUTO_INCREMENT,
`code` VARCHAR(20) COLLATE utf8mb4_bin DEFAULT NULL,
`age` INT DEFAULT '0',
`name` VARCHAR(30) COLLATE utf8mb4_bin DEFAULT NULL,
`height` INT DEFAULT '0',
`address` VARCHAR(30) COLLATE utf8mb4_bin DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `idx_code_age_name` (`code`,`age`,`name`),
KEY `idx_height` (`height`)
)

建立联合索引:idx_code_age_name。

该索引字段的顺序是:

code

age

name

然后插入一组数据

INSERT INTO 数据库.`user` (id,CODE,age,NAME,height,address) VALUES(DEFAULT,'1002',40,'kevin',180,'北京市');

以下会走索引

select * from user where code='1002';
select * from user where code='1002' and age=40
select * from user where code='1002' and age=401 and name='kevin';
select * from userwhere code = '1002' and name='kevin';

我们通过 EXPLAIN加上面的任意语句执行

EXPLAIN SELECT * FROM USER WHERE CODE = '1002' AND NAME='kevin';

都会看到 type值 为ref

教您彻底理解索引的最左匹配原则!

 

 

以下不会走索引

select * from user where age=21;
select * from user where name='Kevin';
select * from user where age=21 and name='Kevin';

我们通过 EXPLAIN加上面的任意语句执行,会看到type值为all

教您彻底理解索引的最左匹配原则!

 

大家可以看到where 从code(从左到右依次是:code、age、name)的联合索引,开始查询就会走索引,如果不从code开始就不会走索引!即只有左边的字段被用到,右边的才能够被使用到

explain 的常用type值

这里先简单的说一下explain,explain即执行计划,使用explain关键字可以模拟优化器执行sql查询语句,从而知道MySQL是如何处理sql语句。explain主要用于分析查询语句或表结构的性能瓶颈。

explain 的常用type值含义如下:

· "ALL"表示全表扫描,没有使用索引。

· "index"表示使用了索引,但不是覆盖索引(即查询中使用了索引,但还需要回表获取数据)。

· "range"表示使用了覆盖索引(即查询中直接从索引中获取了所需数据,无需回表)。

· "ref"表示使用了索引(可能是覆盖索引或非覆盖索引),并使用了一个或多个列进行比较。

· "eq_ref"表示使用了唯一索引,并且只使用了等于操作符进行比较。

我的每一篇文章都希望帮助读者解决实际工作中遇到的问题!如果文章帮到了您,劳烦点赞、收藏、转发!您的鼓励是我不断更新文章最大的动力!



Tags:索引   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
生成式人工智能在搜索引擎优化(SEO)中的应用顶级案例
原文作者 | Rahul Solanki生成式人工智能正在迅速改变搜索引擎优化 (SEO) 的工作方式。 这些新时代的语言模型和机器学习系统不仅可以研究大量信息,还可以理解上下文和含义,并...【详细内容】
2024-03-27  Search: 索引  点击:(9)  评论:(0)  加入收藏
Google搜索引擎索引的网页数量有多少?谷歌官方提供数据进行参考
Google搜索引擎索引的网页数量有多少?二十世纪九十年代,网页的索引数量成了一个各大搜索引擎相互对比的指标。小编记得2000年谷歌搜索引擎的首页搜索框上方,还标记着谷歌索引的...【详细内容】
2024-03-27  Search: 索引  点击:(12)  评论:(0)  加入收藏
MySQL:BUG导致DDL语句无谓的索引重建
对于5.7.23之前的版本在评估类似DDL操作的时候需要谨慎,可能评估为瞬间操作,但是实际上线的时候跑了很久,这个就容易导致超过维护窗口,甚至更大的故障。一、问题模拟使用5.7.22...【详细内容】
2024-03-26  Search: 索引  点击:(8)  评论:(0)  加入收藏
sem搜索引擎营销目标定位
当我们使用百度付费的竞价推广来做搜索引擎营销的时候,目标要定位好,这样才能把搜索营销的效果更大化,才能把七七鱼的竞价宗旨:花较少的钱得到更多的回报,发挥好。否则是花大钱也...【详细内容】
2024-03-25  Search: 索引  点击:(14)  评论:(0)  加入收藏
SEO优化全攻略:让你的网站在搜索引擎中脱颖而出
在这个数字化飞速发展的时代,拥有一个网站已不再是企业或个人的选择,而是必需品。然而,仅仅拥有一个网站并不足以吸引大量的流量和客户。为了让你的网站在众多竞争对手中脱颖而...【详细内容】
2024-03-25  Search: 索引  点击:(4)  评论:(0)  加入收藏
怎样知道域名有没有被搜索引擎惩罚过?
在网站推广的过程中,很多企业创建很多站点,我们会涉及到购买域名,那么如何判断域名是否被惩罚过?今天小编就跟大家来说说具体如何查询。1、网站收录如果你购买的域名可能是老域...【详细内容】
2024-03-21  Search: 索引  点击:(6)  评论:(0)  加入收藏
鲜为人知的搜索引擎优化(SEO)秘籍
随着互联网的普及和发展,搜索引擎优化(SEO)已经成为企业和个人在网络世界中争夺流量和曝光的重要手段。然而,很多从业者对于SEO的理解仍然停留在表面,实际上,有一些鲜为人知的SEO...【详细内容】
2024-03-12  Search: 索引  点击:(17)  评论:(0)  加入收藏
有什么办法能让新网站被百度等搜索引擎快速收录?,搜索引擎收录的原理
为了使新的网站能尽快被主流搜寻引擎如百度所收录,有几种行之有效的策略值得我们借鉴。这篇文章我将为大家提供九个切实可行的提示,以提升网站知名度,从而吸引更广泛的用户群体...【详细内容】
2024-03-12  Search: 索引  点击:(21)  评论:(0)  加入收藏
宝藏级Go语言开源项目——教你自己动手开发互联网搜索引擎
DIYSearchEngine 是一个能够高速采集海量互联网数据的开源搜索引擎,采用 Go 语言开发。Github 地址:https://github.com/johnlui/DIYSearchEngine运行方法首先,给自己准备一杯...【详细内容】
2024-03-12  Search: 索引  点击:(18)  评论:(0)  加入收藏
准线上事故之MySQL优化器索引选错
1 背景最近组里来了许多新的小伙伴,大家在一起聊聊技术,有小兄弟提到了MySQL的优化器的内部策略,想起了之前在公司出现的一个线上问题,今天借着这个机会,在这里分享下过程和结论...【详细内容】
2024-03-07  Search: 索引  点击:(26)  评论:(0)  加入收藏
▌简易百科推荐
小红书、视频号、抖音流量算法解析,干货满满,值得一看!
咱们中国现在可不是一般的牛!网上的网友已经破了十个亿啦!到了这个互联网的新时代,谁有更多的人流量,谁就能赢得更多的掌声哦~抖音、小红书、、视频号,是很多品牌必争的流量洼地...【详细内容】
2024-02-23  二手车小胖说    Tags:流量算法   点击:(12)  评论:(0)  加入收藏
雪花算法详解与Java实现:分布式唯一ID生成原理
SnowFlake 算法,是 Twitter 开源的分布式 ID 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 ID。在分布式系统中的应用十分广泛,且 ID 引入了时间戳...【详细内容】
2024-02-03   一安未来  微信公众号  Tags:雪花算法   点击:(50)  评论:(0)  加入收藏
程序开发中常用的十种算法,你用过几种?
当编写程序时,了解和使用不同的算法对解决问题至关重要。以下是C#中常用的10种算法,每个算法都伴随着示例代码和详细说明。1. 冒泡排序 (Bubble Sort):冒泡排序是一种简单的比...【详细内容】
2024-01-17  架构师老卢  今日头条  Tags:算法   点击:(44)  评论:(0)  加入收藏
百度推荐排序技术的思考与实践
本文将分享百度在推荐排序方面的思考与实践。在整个工业界的推广搜场景上,特征设计通常都是采用离散化的设计,需要保证两方面的效果,一方面是记忆,另一方面是泛化。特征都是通过...【详细内容】
2024-01-09  DataFunTalk  微信公众号  Tags:百度推荐   点击:(73)  评论:(0)  加入收藏
什么是布隆过滤器?如何实现布隆过滤器?
以下我们介绍了什么是布隆过滤器?它的使用场景和执行流程,以及在 Redis 中它的使用,那么问题来了,在日常开发中,也就是在 Java 开发中,我们又将如何操作布隆过滤器呢?布隆过滤器(Blo...【详细内容】
2024-01-05  Java中文社群  微信公众号  Tags:布隆过滤器   点击:(87)  评论:(0)  加入收藏
面向推荐系统的深度强化学习算法研究与应用
随着互联网的快速发展,推荐系统在各个领域中扮演着重要的角色。传统的推荐算法在面对大规模、复杂的数据时存在一定的局限性。为了解决这一问题,深度强化学习算法应运而生。本...【详细内容】
2024-01-04  数码小风向    Tags:算法   点击:(89)  评论:(0)  加入收藏
非负矩阵分解算法:从非负数据中提取主题、特征等信息
非负矩阵分解算法(Non-negativeMatrixFactorization,简称NMF)是一种常用的数据分析和特征提取方法,主要用于从非负数据中提取主题、特征等有意义的信息。本文将介绍非负矩阵分解...【详细内容】
2024-01-02  毛晓峰    Tags:算法   点击:(62)  评论:(0)  加入收藏
再谈前端算法,你这回明白了吗?
楔子 -- 青蛙跳台阶一只青蛙一次可以跳上一级台阶,也可以跳上二级台阶,求该青蛙跳上一个n级的台阶总共需要多少种跳法。分析: 当n=1的时候,①只需要跳一次即可;只有一种跳法,即f(...【详细内容】
2023-12-28  前端爱好者  微信公众号  Tags:前端算法   点击:(107)  评论:(0)  加入收藏
三分钟学习二分查找
二分查找是一种在有序数组中查找元素的算法,通过不断将搜索区域分成两半来实现。你可能在日常生活中已经不知不觉地使用了大脑里的二分查找。最常见的例子是在字典中查找一个...【详细内容】
2023-12-22  小技术君  微信公众号  Tags:二分查找   点击:(78)  评论:(0)  加入收藏
强化学习算法在资源调度与优化中的应用
随着云计算和大数据技术的快速发展,资源调度与优化成为了现代计算系统中的重要问题。传统的资源调度算法往往基于静态规则或启发式方法,无法适应动态变化的环境和复杂的任务需...【详细内容】
2023-12-14  职场小达人欢晓    Tags:算法   点击:(164)  评论:(0)  加入收藏
站内最新
站内热门
站内头条