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,就说明所有的字段都是走索引的。

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

相关推荐
唐青枫19 小时前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
小满87819 小时前
5.Mysql事务隔离级别与锁机制
mysql
元Y亨H2 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵3 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking3 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
李白客5 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
Jim6007 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL7 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql