17.MySql 联合索引 左前缀法则和范围查询

我们之前已经给tb_user 添加了索引 show index from tb_user;

左前缀法则

在 tb_user 表中,有一个联合索引,这个联合索引涉及到三个字段,顺序分别为:profession, age,status。

对于最左前缀法则指的是,查询时,最左边 的列,也就是profession必须存在(最左边列存在就行不管顺序如何),否则索引全部失效。而且中间不能跳过某一列,否则该列后面的字段索引将失效。 接下来,我们来演示几组案例,看一下具体的执行计划:

A. profession age status全部存在key_len 是54

ini 复制代码
explain
select *
from tb_user
where profession = '软件工程'
  and age = 31
  and status = '0';

B.我们将status条件删除 key_len 是49 代表status长度是5

csharp 复制代码
explain select * from tb_user where profession = '软件工程' and age = 31;

C.单独查询 profession 长度是47 status长度是5 age索引长度是2

csharp 复制代码
explain select * from tb_user where profession = '软件工程';

D.删除profession 查询条件

csharp 复制代码
explain select * from tb_user where age = 31 and status = '0';

explain select * from tb_user where status = '0';

而通过上面的这两组测试,我们也可以看到索引并未生效,原因是因为不满足最左前缀法则,联合索引最左边的列profession不存在

E.删除age

csharp 复制代码
explain select * from tb_user where profession = '软件工程' and status = '0 ';

从key_len长度47判断出来 跳过了age这个列,所以后面的列索引是不会使用的,也就是索引部分生效,所以索引的长度就是47

F.当查询条件索引顺序被打乱 是否满足最左前缀法则,走不走上述的联合索引

csharp 复制代码
explain select * from tb_user where age = 31 and status = '0' and profession = '软件工程';

最左前缀法则中指的最左边的列,是指在查询时,联合索引的最左边的字段(即是第一个字段)必须存在,与我们编写SQL时,条件编写的先后顺序无关。

范围查询

联合索引中,出现范围查询(>,<),范围查询右侧的列索引失效。

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

当范围查询使用> 或 < 时,走联合索引了,但是索引的长度为49,就说明范围查询右边的status字段是没有走索引的。

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

当范围查询使用>= 或 <= 时,走联合索引了,但是索引的长度为54,就说明所有的字段都是走索引的。

所以,在业务允许的情况下 ,尽可能的使用类似于 >= 或 <= 这类的范围查询,而避免使用 > 或 <

相关推荐
C137的本贾尼3 小时前
深入 ACID 与事务隔离级别
mysql
CodeStats3 小时前
从JDBC时代到MyBatis封神:SQL全流程手写ORM实战
sql·mysql·mybatis
Lyyaoo.3 小时前
【MySQL】存储引擎
数据库·mysql
曾瑞铭Raymond3 小时前
【侄女零基础升级打怪】Vibe Coding氛围编程 AI编程之MySQL 新手学习指引
mysql·ai编程·零基础学ai·瑞铭进阶升级练习稿·ai氛围编程思维
AOwhisky4 小时前
学习自测与解析:MySQL 系列第三期与第四期
linux·运维·数据库·学习·mysql·云计算
程序猿乐锅4 小时前
【MySQL | 第七篇】 索引使用规则
数据库·sql·mysql
Lyyaoo.4 小时前
【MySQL】锁机制
android·数据库·mysql
锋行天下5 小时前
中小项目高可用,真的需要K8s吗?从单机备份到企业级架构的完整思考
后端·mysql·nginx
無限進步D5 小时前
MySQL 约束
数据库·mysql