请选择 进入手机版 | 继续访问电脑版

[MySql] MySQL索引下推(ICP)的简单明白 与示例

[复制链接]
查看102 | 回复9 | 2021-9-13 00:16:51 | 显示全部楼层 |阅读模式

媒介

索引下推(Index Condition Pushdown, 简称ICP)是MySQL 5.6 版本的新特性,它能减少回表查询次数,提升 检索服从 。

MySQL体系布局

要明确 索引下推,起首 要相识 MySQL的体系布局 :

MySQL索引下推(ICP)的简单明白
与示例

上图来自MySQL官方文档

通常把MySQL从上至下分为以下几层:

  • MySQL服务层:包括NoSQL和SQL接口、查询分析 器、优化器、缓存和Buffer等组件。
  • 存储引擎层:各种插件式的表格存储引擎,实现变乱 、索引等各种存储引擎干系 的特性。
  • 文件体系 层: 读写物理文件。

MySQL服务层负责SQL语法分析 、触发器、视图、内置函数、binlog、天生 实行 计划等,并调用存储引擎层去实行 数据的存储和检索。“索引下推”的“下”实在 就是指将部分上层(服务层)负责的变乱 ,交给了下层(存储引擎)行止 理。

索引下推案例

假设用户表数据和布局 如下:

id age birthday name
1 18 01-01 User1
2 19 03-01 User2
3 20 03-01 User3
4 21 03-01 User4
5 22 05-01 User5
6 18 06-01 User6
7 24 01-01 User7

创建一个团结 索引(age, birthday),并查询出年事 >20,且生日为03-01的用户:

  1. select * from user where age>20 and birthday="03-01"
复制代码

由于age字段使用 了范围查询,根据最左前缀原则,这种环境 只能使用 age字段举行 范围查询,索引中的birthday字段无法使用 。使用 explain查看实行 计划:

  1. +------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+
  2. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
  3. +------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+
  4. | 1 | SIMPLE | user | range | age_birthday | age_birthday | 4 | NULL | 3 | Using index condition |
  5. +------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+
复制代码

可以看到固然 使用 了age_birthday索引,但是索引长度key_len只有4,阐明 只有团结 索引只有age字段见效 了(由于 age字段是int范例 ,占用4个字节)。末了 Extra列的Using index condition表示这个查询使用 了索引下推优化。

为在没有索引下推的环境 下,实行 步骤如下:

  • 存储引擎根据索引查找出age>20的用户id,分别是:4,5,7
  • 存储引擎到表格中取出id in (4,5,7)的3条记录,返回给服务层
  • 服务层过滤掉不符合birthday="03-01"条件的记录,末了 返回查询结果 为id=4的1行记录。

假如 开启了索引下推优化,实行 步骤如下:

  1. 存储引擎根据索引查找出age>20的用户id,并使用 索引中的birthday字段过滤掉不符合birthday="03-01"条件的记录,末了 得到id=4;
  2. 存储引擎到表格中取出id=4的1条记录,返回给服务层;
  3. 服务层过滤掉不符合birthday="03-01"条件的记录,末了 返回查询结果 为id=4的1行记录。

启用索引下推后,把where条件由MySQL服务层放到了存储引擎层去实行 ,带来的好处就是存储引擎根据id到表格中读取数据的次数变少了。在上面这个例子中,没有索引下推时必要 多回表查询2次。并且回表查询很大概 是离散IO,在某些环境 下,对数据库性能会有较大提升 。

总结

到此这篇关于MySQL索引下推(ICP)的简单明确 与示例的文章就先容 到这了,更多干系 MySQL索引下推(ICP)内容请搜刮 脚本之家从前 的文章或继续欣赏 下面的干系 文章盼望 大家以后多多支持脚本之家!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复

使用道具 举报

avatar hhhong2017 | 2021-9-19 17:03:40 | 显示全部楼层
宇宙第一贴诞生了!
回复

使用道具 举报

avatar 淡淡清水1314 | 2021-10-3 02:07:29 | 显示全部楼层
一口气看完了,我要下去回味回味了!
回复

使用道具 举报

avatar 猥琐大叔求教pv | 2021-10-11 15:10:59 | 显示全部楼层
看了这么多帖子,第一次看到这么有深度了!
回复

使用道具 举报

avatar SUNSHINEhzl | 2021-10-11 16:14:51 | 显示全部楼层
楼上的别说的那么悲观好吧!
回复

使用道具 举报

avatar 科林回拔 | 2021-10-11 16:35:38 | 显示全部楼层
吹牛的人越来越多了!
回复

使用道具 举报

avatar 青丝暮雪780 | 2021-10-15 20:58:27 | 显示全部楼层
最近精神病院在打折,admin楼主去看看吧?
回复

使用道具 举报

admin楼主,您提前出院了?
回复

使用道具 举报

admin楼主人气很旺!
回复

使用道具 举报

avatar 静美人2017 | 昨天 03:13 | 显示全部楼层
看在admin楼主的面子上,认真回帖!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则