MySQL-索引下推

MySQL-索引下推

前言

MySQL5.6 引入了一项查询优化技术:索引下推(Index Condition Pushdown,简称 ICP)

目前只有MyISAMInnoDB 支持了ICP

下面就来简单讲讲到底什么是ICP吧。

MySQL服务层与存储引擎层

在MySQL初期设计时,由于当时的局限性,以及为了对MySQL服务层存储引擎层 进行职责划分,所以存储引擎层 的主要职责是快速借助索引定位数据,然后将数据返回给MySQL服务层,服务层可以更好更快速的对数据进行过滤处理。

所以存储引擎层 为了快速地定位数据,只会进行简单的数据过滤。也就是说,如果查询语句的where 后通过and 连接了多个过滤条件,存储引擎层一般只会执行部分简单的条件。

例如:SELECT * FROM users WHERE age > 30 AND name LIKE 'A%'; 就算有联合索引(age,name) ,存储引擎也只会执行age>30 ,将符合该条件的数据全部返回给MySQL服务层 ,再由服务层对数据进行name LIKE 'A%' 条件过滤。

ICP

通过前面的讲解,我们知道了,由于初期MySQL设计的局限性,存储引擎层 没有充分的用到索引,导致返回了大量多余数据给MySQL服务层 ,此外存储引擎层在数据查询时也容易产生多余的回表操作。

MySQL完全可以在存储引擎层 利用联合索引(age,name) ,执行完被索引覆盖 的全部的 age > 30 AND name LIKE 'A%' 过滤条件,就可以返回较少的数据给MySQL服务层 。这个技术就是ICP

可以看到,ICP 就是将MySQL服务层 需要执行的部分复杂条件过滤下推存储引擎层 执行,有利于减少存储引擎层与MySQL服务层之间的数据传输开销 ,也有利于减少回表,提高MySQL查询效率。

补充

ICP 在查询条件能够被索引覆盖的情况下才有意义,所以联合索引覆盖索引ICP 以及其它优化查询的技术之间往往是相辅相成的。

相关推荐
草莓熊Lotso5 分钟前
手搓工业级 C++ 线程安全日志系统:基于策略模式解耦,兼容 glog 使用风格
linux·运维·服务器·数据库·c++·安全·策略模式
2402_854808376 分钟前
c++ RAII机制详解 c++如何利用RAII管理资源
jvm·数据库·python
吕源林7 分钟前
CSS如何使用Less的Merge功能合并多个属性值_通过逗号或空格组织css参数
jvm·数据库·python
qq_330037998 分钟前
Go语言如何写负载均衡器_Go语言负载均衡器实战教程【完整】
jvm·数据库·python
2501_914245938 分钟前
如何验证SQL删除操作的影响行数_通过ROW_COUNT获取反馈
jvm·数据库·python
2301_816660218 分钟前
如何处理DG Broker的ORA-16664错误_主备库网络通信与TNS配置排查
jvm·数据库·python
2401_8359568110 分钟前
mysql如何配置用户只读权限_授予SELECT权限与限制操作
jvm·数据库·python
weixin_4087177711 分钟前
HTML怎么标注成就连续打卡中断_HTML“断连,重新开始”提示【方法】
jvm·数据库·python
m0_7436239211 分钟前
怎么通过Navicat快速实现离线模式下使用云端资源_企业协同实战指南
jvm·数据库·python
Caspian Wren13 分钟前
通过Canal、Canal adapter将MySQL数据同步到ES
mysql·elasticsearch·adb