news 2026/4/16 9:49:03

MySQL索引使用--最左前缀法则

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL索引使用--最左前缀法则

验证索引效率

在未建立索引之前,执行如下SQL语句,查询SQL的耗时:

select * from tb_sku where sn='SN0003450001'

针对字段创建索引

create index idx_sku_sn on tb_sku(sn);

创建完索引之后,再来看这条查询sql的耗时。

查看sql的执行计划

最左前缀法则:

如果索引了多列(联合索引),要遵守最左前缀法则。最左前缀法则指的是查询从索引的最左列开始,并且不跳过索引中的列。如果跳跃某一列,索引将部分失效(后面的字段索引失效)。

-- 1. 查询profession、age、status三个条件 explain select * from tb_user where profession = '软件工程' and age = 31 and status = '0'; -- 2. 查询profession、age两个条件 explain select * from tb_user where profession = '软件工程' and age = 31; -- 3. 仅查询profession条件 explain select * from tb_user where profession = '软件工程'; -- 4. 查询age、status两个条件(缺少profession) explain select * from tb_user where age = 31 and status = '0'; -- 5. 仅查询status条件 explain select * from tb_user where profession = '软件工程' and status = '0';

tb_user表中的索引如下

最左前缀法则的验证:

a)执行

select * from tb_user where profession='软件工程' and age=31 and status='0';

可能使用的索引是 idx_pro_age_sta; 实际使用的索引是 idx_pro_age_sta;

b)执行

select * from tb_user where profession = '软件工程' and age = 31;

可能使用的索引是idx_pro_age_sta, 实际使用的索引是idx_pro_age_sta;idx_pro_age_sta;

c) 执行

select * from tb_user where profession = '软件工程';

可能使用的索引是idx_pro_age_sta, 实际使用的索引是idx_pro_age_staidx_pro_age_sta

d)执行

select * from tb_user where age = 31 and status = '0';

没有匹配的索引可以使用。

e)执行

select * from tb_user where profession = '软件工程' and status = '0';

索引的长度是43,说明只有profession字段使用到了索引; status字段的索引失效。

f)执行

select * from tb_user where age = 31 and status = '0' and profession = '软件工程';

索引长度是55,说明三个字段的索引都用上了。这说明字段在where条件中的位置无关。

范围查询,联合索引中,出现范围查询(>,

explain select * from tb_user where profession = '软件工程' and age > 30 and status ='0'; explain select * from tb_user where profession = '软件工程' and age >= 30 and status = '0';

age 使用了范围查询,age右边的列status会失效,因此索引的长度是48.

age 使用>=的范围查询时,age右边的列不会索引失效。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:02:18

java基础八股

怎么理解面向对象?简单说说封装继承多态 面向对象是一种编程范式,它将现实世界中的事物抽象为对象,对象具有属性(称为字段或属性)和行为(称为方法)。面向对象编程的设计思想是以对象为中心&…

作者头像 李华
网站建设 2026/4/16 11:57:20

Visual Basic 多媒体应用

多媒体技术使得计算机具有类似人的视觉能力和听说能力,综合处理多媒体信息,包括文本、图形、图像和声音以及动画等。利用Visual Basic提供的MMControl控件,可以很方便地实现文字、图形、图像和声音等文件的播放。MMControl控件在ActiveX部件中…

作者头像 李华
网站建设 2026/4/16 16:57:03

KeymouseGo终极指南:自动化操作从零到精通的完整方案

还在为每天重复点击鼠标、填写表单而烦恼吗?🤔 工作效率低下,时间都浪费在机械性操作上?现在,一款名为KeymouseGo的自动化神器可以帮你彻底解决这些痛点! 【免费下载链接】KeymouseGo 类似按键精灵的鼠标键…

作者头像 李华
网站建设 2026/4/16 15:32:10

Quorum NWR机制

Quorum NWR 解决 AP 系统强一致性需求 在 AP 型分布式系统中实现强一致性需求时,Quorum NWR 提供了一种灵活的解决方案,无需重构系统或迁移数据。以下是其核心原理和实现方法: N(副本数) 副本数指数据在集群中的副本数…

作者头像 李华
网站建设 2026/4/16 10:46:06

深入解析strrchr:字符串中的“末次侦探”

<摘要> strrchr是C标准库中一个功能独特且实用的字符串函数&#xff0c;它像一位从末尾开始工作的侦探&#xff0c;专门在字符串中查找指定字符最后一次出现的位置。本文将用生动的比喻&#xff08;如侦探故事、路标指示等&#xff09;通俗解释其功能&#xff0c;详细剖析…

作者头像 李华