【MySQL实战笔记】 05 | 深入浅出索引(下)-02

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【4月更文挑战第16天】B+树索引利用最左前缀原则加速检索,即使只是部分字段匹配也能生效。联合索引[name-age]可按最左字段"张"找到记录,并遍历获取结果。优化索引顺序能减少维护成本,通常先考虑复用性。若需独立查询部分字段,则需权衡空间占用,如(name,age)与(age)。索引下推自MySQL5.6起,允许在索引遍历时预过滤条件,减少回表次数,提高效率。

最左前缀原则

B+树这种索引结构可以利用索引的"最左前缀"来定位记录。

使用上文中的[name-age]联合索引分析
2024-04-19-20-47-41-image.png

索引项是按照索引定义里面出现的字段排序的。当需要查询所有姓名是“张三”的人时,可以快速定位到ID4,然后向后遍历得到所有需要的结果。如果是要查所有第一个名字里是“张”的人,也可以用上这个索引,查到第一个符合条件的记录是ID3,然后向后遍历,直到不满足条件为止。

不只是索引的全部定义,只要满足最左前缀,就可以利用索引来加速检索。这个前缀可以是联合索引的最左N个字段,也可以是字符串索引的最左M个字符

思考一个比较经典的问题:在建立联合索引的时候,如果安排索引内的字段顺序?

这里的评估标准是索引的复用能力。因为可以支持最左前缀,当已经有了(a,b)这个联合索引后,一般就不需要单独在a上建立索引了。因此,第一原则是,如果通过调整顺序可以少维护一个索引,那么这个顺序就是优先考虑要采用的

如果又有联合查询,又有基于a,b各自的查询呢?查询条件里只有b的语句,是无法使用(a,b)这个联合索引的,这时候需要同时维护(a,b)和(b)这两个索引。这时候要考虑的原则就是空间了,比如上面的例子里,name字段要比age字段大,就更建议创建(name,age)的联合索引和(age)的单字段索引。

索引下推

在最左前缀原则里,最左前缀可以用于在索引中定位记录。那那些不符合最左前缀的部分会怎么样呢?

还是以市民表的联合索引(name,age)为例。现在的需求是:检索出表里“第一个名字是张,而且年龄是10岁的所有男孩”

select * from tuser where name like '张%' and age=10 and ismale=1;

这个语句在搜索索引树的时候,只能用“张”找到第一个满足条件的记录ID3.然后判断其他条件是否满足。

在MySQL5.6之前,只能从ID3开始一个个回表,到主键索引上找出数据行,再对比字段值。
2024-04-19-21-30-54-image.png

在MySQL5.6以后,引入了索引下推优化,在索引遍历过程中,对索引中包含的字段先做判断,直接过滤掉不满足条件的记录,减少回表次数。
2024-04-19-21-31-01-image.png

每个虚线箭头表示回表一次。第二种的区别是InnoDB在(name,age)索引内部就判断了age是否等于10,对不等于10的记录,直接判断并跳过。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
SQL 存储 关系型数据库
MySQL索引及事务
MySQL索引及事务
21 2
|
1天前
|
SQL 存储 关系型数据库
必知的 MySQL 索引失效场景【包括实践验证】,别再踩坑了!(下)
必知的 MySQL 索引失效场景【包括实践验证】,别再踩坑了!
19 2
|
1天前
|
SQL 关系型数据库 MySQL
必知的 MySQL 索引失效场景【包括实践验证】,别再踩坑了!(上)
必知的 MySQL 索引失效场景【包括实践验证】,别再踩坑了!
17 2
|
1天前
|
NoSQL 关系型数据库 MySQL
B+树 和 跳表 的结构及区别,不同的用途【mysql的索引为什么使用B+树而不使用跳表?】
B+树 和 跳表 的结构及区别,不同的用途【mysql的索引为什么使用B+树而不使用跳表?】
16 2
|
1天前
|
存储 算法 关系型数据库
MySQL索引详解
MySQL索引详解
13 0
|
1天前
|
存储 关系型数据库 MySQL
【MySQL系列笔记】分库分表
分库分表是一种数据库架构设计的方法,用于解决大规模数据存储和处理的问题。 分库分表可以简单理解为原来一个表存储数据现在改为通过多个数据库及多个表去存储,这就相当于原来一台服务器提供服务现在改成多台服务器组成集群共同提供服务。
28 8
|
1天前
|
存储 SQL 关系型数据库
完蛋!? 我被MySQL索引失效包围了!
完蛋!? 我被MySQL索引失效包围了!
|
1天前
|
SQL 存储 关系型数据库
MySQL的3种索引合并优化??or到底能不能用索引?
MySQL的3种索引合并优化??or到底能不能用索引?
|
1天前
|
存储 SQL 关系型数据库
MySQL索引,看这一篇就够了!
MySQL索引,看这一篇就够了!
|
1天前
|
Java 关系型数据库 MySQL
MySQL 索引事务
MySQL 索引事务
13 0
http://www.vxiaotou.com