MySQL联合索引遵循最左前缀匹配原则

 更新时间:2022年08月16日 09:51:54   作者:​​​​​​​一灯架构  
这篇文章主要介绍了MySQL联合索引遵循最左前缀匹配原则, MySQL联合索引遵循最左前缀匹配原则,即最左优先,查询的时候会优先匹配最左边的索引

面试官: 我看你的简历上写着精通MySQL,问你个简单的问题,MySQL联合索引有什么特性?

心想,这还不简单,这不是问到我手心里了吗?

听我给你背一遍八股文!

我: MySQL联合索引遵循最左前缀匹配原则,即最左优先,查询的时候会优先匹配最左边的索引。

例如当我们在 (a,b,c) 三个字段上创建联合索引时,实际上是创建了三个索引,分别是(a)、(a,b)、(a,b,c)。

查询条件中包含这些索引的时候,查询就会用到索引。例如下面的查询条件,就可以用到索引:

select * from table_name where a=?;
select * from table_name where a=? and b=?;
select * from table_name where a=? and b=? and c=?;

其他查询条件不包含这些索引的语句,就不会用到索引,例如:

select * from table_name where b=?;
select * from table_name where c=?;
select * from table_name where b=? and c=?;

如果查询条件包含(a,c),也会用到索引,相当于用到了(a)索引。

面试官: 小伙子,你的八股文背的挺熟啊。

我: 也没有辣,我只是平常热爱学习知识,经常做一些总结汇总,所以就脱口而出了。

面试官: 别开染坊了,我再问你,MySQL联合索引一定遵循最左前缀匹配原则吗?

我擦,这把我问的不自信了。

我: 嗯,MySQL联合索引可能有时候不遵循最左前缀匹配原则。

面试官: 什么时候遵循?什么时候不遵循?

我: 可能是晴天遵循,下雨了就不遵循了,每个月那几天不舒服的时候也不遵循了……

面试官: 今天面试就到这吧,你先回去等通知,有后续消息会联系你的。

我擦,这叫什么问题啊?

什么遵循不遵循?

难道是面试官跟我背的八股文不是同一套?

回去到MySQL官网上翻了一下,才发现面试官想问的是索引跳跃扫描(Index Skip Scan) 。

MySQL8.0版本开始增加了索引跳跃扫描的功能,当第一列索引的唯一值较少时,即使where条件没有第一列索引,查询的时候也可以用到联合索引。

造点数据验证一下,先创建一张用户表:

CREATE TABLE `user` (
  `id` int NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(255) NOT NULL COMMENT '姓名',
  `gender` tinyint NOT NULL COMMENT '性别',
  PRIMARY KEY (`id`),
  KEY `idx_gender_name` (`gender`,`name`)
) ENGINE=InnoDB COMMENT='用户表';

在性别和姓名两个字段上(gender,name)建立联合索引,性别字段只有两个枚举值。

执行SQL查询验证一下:

explain select * from user where name='一灯';

虽然SQL查询条件只有name字段,但是从执行计划中看到依然是用了联合索引。

并且Extra列中显示增加了Using index for skip scan,表示用到了索引跳跃扫描的优化逻辑。

具体优化方式,就是匹配的时候遇到第一列索引就跳过,直接匹配第二列索引的值,这样就可以用到联合索引了。

其实我们优化一下SQL,把第一列的所有枚举值加到where条件中,也可以用到联合索引:

select * from user where gender in (0,1) and name='一灯';

看来还是需要经常更新自己的知识体系,一不留神就out了!

到此这篇关于MySQL联合索引遵循最左前缀匹配原则的文章就介绍到这了,更多相关MySQL联合索引遵内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql数据表分区技术PARTITION浅析

    Mysql数据表分区技术PARTITION浅析

    这篇文章主要介绍了Mysql数据表分区技术PARTITION浅析,分别介绍了 Mysql 中的分区技术 RANGE、LIST、 HASH,需要的朋友可以参考下
    2014-06-06
  • mysql中ALTER AGGREGATE使用场景小结

    mysql中ALTER AGGREGATE使用场景小结

    ALTER AGGREGATE 是 SQL 中用于修改已定义聚合函数的语法,本文主要介绍了mysql中ALTER AGGREGATE使用场景小结,具有一定的的参考价值,感兴趣的可以了解一下
    2025-05-05
  • MySQL笔记之运算符使用详解

    MySQL笔记之运算符使用详解

    运算符包括四类,分别是:算数运算符、比较运算符、逻辑运算符和位运算符
    2013-05-05
  • MySQL重定位数据目录的方法

    MySQL重定位数据目录的方法

    这篇文章主要介绍了MySQL重定位数据目录的实现方法,分析了重定位MySQL数据目录的实现原理与技巧,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • 关于MySQL的整型数据的内存溢出问题的应对方法

    关于MySQL的整型数据的内存溢出问题的应对方法

    这篇文章主要介绍了关于MySQL的整型数据的内存溢出问题的应对方法,作者还列出了MySQL所支持的整型数据的存储空间支持大小,需要的朋友可以参考下
    2015-05-05
  • mysql优化配置参数

    mysql优化配置参数

    mysql安装好需要优化配置一下,打开c:\windows\my.ini文件
    2011-03-03
  • Navicat无法连接MySQL报错1251的解决方案

    Navicat无法连接MySQL报错1251的解决方案

    这篇文章主要为大家详细介绍了Navicat无法连接MySQL报错1251的解决方案,文中解决方法介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2023-12-12
  • MySQL数据库读写分离与负载均衡的实现逻辑

    MySQL数据库读写分离与负载均衡的实现逻辑

    读写分离与负载均衡是数据库优化的关键策略,读写分离的核心是将数据库的读操作与写操作分离,本文给大家介绍MySQL数据库读写分离与负载均衡的实现方式,感兴趣的朋友一起看看吧
    2025-11-11
  • mysql查看,创建,授权,删除用户的实现方式

    mysql查看,创建,授权,删除用户的实现方式

    这篇文章主要介绍了mysql查看,创建,授权,删除用户的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • MySQL解决Navicat设置默认字符串时的报错问题

    MySQL解决Navicat设置默认字符串时的报错问题

    本文主要介绍了MySQL解决Navicat设置默认字符串时的报错,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06

最新评论