news 2026/6/12 1:47:32

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/6/10 18:21:42

如何高效使用B站视频下载工具:实用技巧完全攻略

如何高效使用B站视频下载工具:实用技巧完全攻略 【免费下载链接】bilibili-downloader B站视频下载,支持下载大会员清晰度4K,持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 想要永久保存B站上的精彩视…

作者头像 李华
网站建设 2026/5/31 4:30:47

QT实战:qrc资源动态加载

QRC资源文件动态加载 Qt资源系统(QRC)是Qt框架中用于管理二进制资源的机制,通过XML文件描述资源路径,编译时打包到可执行文件中。动态加载QRC文件能提升灵活性和维护性。 基本用法 动态加载的核心是QResource类和QDir的addResourc…

作者头像 李华
网站建设 2026/6/10 14:31:04

完全掌握Windows平台asar文件处理:WinAsar实战指南

完全掌握Windows平台asar文件处理:WinAsar实战指南 【免费下载链接】WinAsar 项目地址: https://gitcode.com/gh_mirrors/wi/WinAsar 还在为Electron应用asar文件处理头疼吗?😫 面对复杂的命令行操作,普通用户往往望而却步…

作者头像 李华
网站建设 2026/6/10 17:26:30

Lumafly终极指南:轻松管理Hollow Knight模组的跨平台神器

Lumafly终极指南:轻松管理Hollow Knight模组的跨平台神器 【免费下载链接】Lumafly A cross platform mod manager for Hollow Knight written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/lu/Lumafly Lumafly是一款专为《空洞骑士》玩家设计的…

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

设计标注工具如何彻底改变你的工作流

设计标注工具如何彻底改变你的工作流 【免费下载链接】sketch-meaxure 项目地址: https://gitcode.com/gh_mirrors/sk/sketch-meaxure "又是凌晨两点,我还在手动标注设计稿的间距和尺寸..." 这是多少设计师的日常?当你面对复杂的界面…

作者头像 李华
网站建设 2026/6/10 14:38:45

如何快速掌握ExifToolGui:照片元数据管理的终极解决方案

如何快速掌握ExifToolGui:照片元数据管理的终极解决方案 【免费下载链接】ExifToolGui A GUI for ExifTool 项目地址: https://gitcode.com/gh_mirrors/ex/ExifToolGui 你是否曾经面对数千张照片却无法快速找到特定时间或地点拍摄的那一张?或者想…

作者头像 李华