MySQL查询性能优化索引下推
作者:一灯架构??????? 发布时间:2024-01-24 15:43:01
前言
前面已经讲了MySQL的其他查询性能优化方式,没看过可以去了解一下:
MySQL查询性能优化七种方式索引潜水
MySQL查询性能优化武器之链路追踪
今天要讲的是MySQL的另一种查询性能优化方式 — 索引下推(Index Condition Pushdown,简称ICP),是MySQL5.6版本增加的特性。
1. 索引下推的作用
主要作用有两个:
减少回表查询的次数
减少存储引擎和MySQL Server层的数据传输量
总之就是了提升MySQL查询性能。
2. 案例实践
创建一张用户表,造点数据验证一下:
CREATE TABLE `user` (
`id` int NOT NULL AUTO_INCREMENT COMMENT '主键',
`name` varchar(100) NOT NULL COMMENT '姓名',
`age` tinyint NOT NULL COMMENT '年龄',
`gender` tinyint NOT NULL COMMENT '性别',
PRIMARY KEY (`id`),
KEY `idx_name_age` (`name`,`age`)
) ENGINE=InnoDB COMMENT='用户表';
在 姓名和年龄 (name
,age
) 两个字段上创建联合索引。
查询SQL执行计划,验证一下是否用到索引下推:
explain select * from user where name='一灯' and age>2;
执行计划中的Extra列显示了Using index condition,表示用到了索引下推的优化逻辑。
3. 索引下推配置
查看索引下推的配置:
show variables like '%optimizer_switch%';
如果输出结果中,显示 index_condition_pushdown=on,表示开启了索引下推。
也可以手动开启索引下推:
set optimizer_switch="index_condition_pushdown=on";
关闭索引下推:
set optimizer_switch="index_condition_pushdown=off";
4. 索引下推原理剖析
索引下推在底层到底是怎么实现的?
是怎么减少了回表的次数?
又减少了存储引擎和MySQL Server层的数据传输量?
在没有使用索引下推的情况,查询过程是这样的:
存储引擎根据where条件中name索引字段,找到符合条件的3个主键ID
然后二次回表查询,根据这3个主键ID去主键索引上找到3个整行记录
把数据返回给MySQL Server层,再根据where中age条件,筛选出符合要求的一行记录
返回给客户端
画两张图,就一目了然了。
下面这张图是回表查询的过程:
先在联合索引上找到name=‘一灯’的3个主键ID
再根据查到3个主键ID,去主键索引上找到3行记录
下面这张图是存储引擎返回给MySQL Server端的处理过程:
我们再看一下在使用索引下推的情况,查询过程是这样的:
存储引擎根据where条件中name索引字段,找到符合条件的3行记录,再用age条件筛选出符合条件一个主键ID
然后二次回表查询,根据这一个主键ID去主键索引上找到该整行记录
把数据返回给MySQL Server层
返回给客户端
现在是不是理解了索引下推的两个作用:
减少回表查询的次数
减少存储引擎和MySQL Server层的数据传输量
5. 索引下推应用范围
适用于InnoDB 引擎和 MyISAM 引擎的查询
适用于执行计划是range, ref, eq_ref, ref_or_null的范围查询
对于InnoDB表,仅用于非聚簇索引。索引下推的目标是减少全行读取次数,从而减少 I/O 操作。对于 InnoDB聚集索引,完整的记录已经读入InnoDB 缓冲区。在这种情况下使用索引下推 不会减少 I/O。
子查询不能使用索引下推
存储过程不能使用索引下推
再附一张Explain执行计划详解图:
来源:https://juejin.cn/post/7129870429090480142


猜你喜欢
- 效果: 思路:利用onmousemove事件,然后获取鼠标的坐标,之后把DIV挨个遍历,最后把鼠标的坐标赋给DIV。代码:<
- 为什么要用flash呢?动画流畅,视觉效果好缓存能力强那使用flash有什么问题呢?需要Flash播放器在M$的补丁打遍天下之前IE有那神奇
- 前言大家可以根据格式化打印字符去调一下最后的输出,不过有中文好像不好调整,可以换成星期的单词,这样应该会好一点,format()函数可以用来
- 本文实例讲述了Python功能键的读取方法。分享给大家供大家参考。具体分析如下:先getch一下得到a,如果等于0或者224,就说明是功能键
- 使用一个遵循buffer protocol的对象就可以和numpy交互了.这个buffer_protocol要有哪些东西呢? 要有如下接口:
- 前言今天帮师兄赶在deadline之前画论文的图,现学现卖很是刺激,现把使用matplotlib的子库pyplot画折线图和柱状图的代码记录
- 前言:流程控制是每种编程语言控制逻辑走向和执行次序的重要部分,流程控制可以说是一门语言的“经脉”。Go语言中最常用的流程控制有if和for,
- 在服务器上生成动态内容是使用ASP最主要的原因之一,所以我们选择的第一个测试项目是确定把动态内容发送到应答流使用什么方法最好。基本的选择有两
- 我就废话不多说了,大家还是直接看代码吧!print("thresh =",thresh)coords = np.colu
- 通过学习装饰器可以让我们更好更灵活的使用函数,通过学会使用装饰器还可以让我们的代码更加优雅。在我们的实际工作中,很多场景都会用到装饰器,比如
- 玩过电脑游戏的同学对于 * 肯定不陌生,但是你在用 * 的时候有没有想过如何做一个 * 呢?(当然用 * 不是那么道义哈,呵呵),那我们就来看一下如
- 本文实例为大家分享了python使用matplotlib画柱状图、散点图的具体代码,供大家参考,具体内容如下柱状图(plt.bar)代码与注
- 很多用ACCEE97开发过数据库的用户都有这种体会:要想在窗体中添加一个命令按钮实现打开通用对话框的功能真是很困难。因为ACCESS97本身
- 关于文件加载及处理1、检查python关于文件加载及处理方式文件路径是否存在,如果不存在就创建此路径。#如果不存在路径,就创建一个这样的路径
- 本文实例讲述了python抽象基类用法。分享给大家供大家参考。具体如下:定义抽象类,需要使用abc模块,该模块定义了一个元类(ABCMeat
- 本教程为大家分享了win10下Python环境安装配置教程,供大家参考,具体内容如下1.在https://www.python.org/do
- 【人工智能项目】混合高斯模型运动目标检测本次工作主要对视频中运动中的人或物的边缘背景进行检测。那么走起来瓷!!!原视频高斯算法提取工作imp
- 经常在办公的过程中会遇到各种各样的压缩文件处理,但是呢每个压缩软件支持的格式又是不同的。没有可以一种可以同时多种格式的并且免费的文件解压缩工
- 目录前言limit深分页为什么会变慢?通过子查询优化回顾B+ 树结构把条件转移到主键索引树INNER JOIN 延迟关联标签记录法使用bet
- 关于webpack的配置和使用,网上已经有许多文章了,大多是在讲单页应用,当我们需要打包多个html时,事情就变得麻烦起来。怎么在webpa