什么是索引下推

索引下推(Index Condition Pushdown,简称ICP)是一种数据库查询优化技术,它利用了数据库引擎中的索引和过滤条件,将部分过滤工作下推到存储引擎层面进行处理,从而减少不必要的数据读取和传输

在传统的查询执行过程中,数据库引擎首先根据索引定位到符合过滤条件的数据行,并将这些行读取到内存中,然后再进行进一步的过滤操作。而索引下推则在这一步骤中尽可能地将过滤操作下推到存储引擎层面,避免将不符合条件的数据行读取到内存中。

具体实现方式可以是通过存储引擎提供的接口或者钩子函数,让存储引擎在读取索引页时就进行额外的过滤操作。

通过索引下推,数据库系统可以在存储引擎层面根据索引和过滤条件提前过滤掉不符合条件的数据,减少了需要传递给查询引擎的数据量和内存消耗。这样可以大大减少磁盘 I/O 和数据传输的开销,提升查询性能和整体系统效率。

需要注意的是,索引下推并不是对所有类型的查询都适用,它更适用于复杂查询条件、多列条件的查询中,能够有效地减少不必要的数据读取和传输。

介绍索引下推

索引下推(INDEX CONDITION PUSHDOWN,简称 ICP)是在 MySQL 5.6 针对扫描二级索引的一项优化改进。总的来说是通过把索引过滤条件下推到存储引擎,来减少 MySQL 存储引擎访问基表的次数以及 MySQL 服务层访问存储引擎的次数。ICP 适用于 MYISAM 和 INNODB,本篇的内容只基于 INNODB。
在讲这个技术之前你得对mysql架构有一个简单的认识,见下图:

  • MySQL 服务层:也就是 SERVER 层,用来解析 SQL 的语法、语义、生成查询计划、接管从 MySQL 存储引擎层上推的数据进行二次过滤等等。
  • MySQL 存储引擎层:按照 MySQL 服务层下发的请求,通过索引或者全表扫描等方式把数据上传到 MySQL 服务层。
  • MySQL 索引扫描:根据指定索引过滤条件,遍历索引找到索引键对应的主键值后回表过滤剩余过滤条件。
  • MySQL 索引过滤:通过索引扫描并且基于索引进行二次条件过滤后再回表。

实战数据准备

delete from user1;
drop table user1;

CREATE TABLE `user1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) NOT NULL,
  `age` tinyint(4) NOT NULL,
	`address` varchar(50) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `idx_name_age` (`name`,`age`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

INSERT INTO `user1` (`name`, `age`, `address`) VALUES
('Alice', 40, 'address1'),
('Amy', 23, 'address2'),
('Tom', 18, 'address3'),
('Mike', 22, 'address4');

explain SELECT * FROM user1 WHERE name LIKE 'A%' and age = 23;

# 查看索引下推是否开启
select @@optimizer_switch
# 开启索引下推
set optimizer_switch="index_condition_pushdown=on";
# 关闭索引下推
set optimizer_switch="index_condition_pushdown=off";

索引下推实战

不使用索引下推实现

Explain SELECT * FROM user1 WHERE name LIKE 'A%' and age = 40;


使用索引下推实现

Explain SELECT * FROM user1 WHERE name LIKE 'A%' and age = 40;

索引下推的使用条件

  • ICP目标是减少全行记录读取,从而减少IO 操作,只能用于非聚簇索引。聚簇索引本身包含的表数据,也就不存在下推一说。
  • 只能用于rangerefeq_refref_or_null访问方法;
  • where 条件中是用 and 而非 or 的时候。
  • ICP适用于分区表。
  • ICP不支持基于虚拟列上建立的索引,比如说函数索引
  • ICP不支持引用子查询作为条件。
  • ICP不支持存储函数作为条件,因为存储引擎无法调用存储函数
  • 21
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 索引是一种优化技术,它可以在查询过程中尽可能地利用索引来减少扫描的数据量,从而提高查询效率。具体来说,当一个查询包含多个条件时,索引可以将这些条件尽可能地索引层级中,以减少需要扫描的数据量。这样可以避免在查询过程中扫描大量的数据块,从而提高查询效率。 ### 回答2: 索引是MySQL数据库中的一种优化技术,它在处理SQL查询时,首先使用索引来过滤掉不符合条件的行,然后再对符合条件的行进行进一步的判断和筛选。 传统的查询方式是,MySQL会先使用索引找到符合条件的行的主键,然后再通过主键去获取完整的行数据。这种方式需要查询两次磁盘或内存,会增加IO负载和查询时间。 而索引则是在执行索引查找的同时,将符合条件的数据进行过滤,减少了对磁盘或内存的读取和查询次数。它可以直接对索引进行访问,然后在索引访问路径上进行条件判断,只将符合条件的行返回给查询结果。这样可以减少对数据块的读取和查询次数,提高查询效率。 索引技术适用于多列查询条件的情况,例如同时使用了多个WHERE子句或使用了多个列的联合索引。它可以在索引的搜索路径上对多个查询条件进行判断,将不符合条件的行直接过滤掉,只返回满足所有条件的行。 需要注意的是,索引并非适用于所有情况,有些查询条件较为复杂或索引选择性较低时,索引的效果可能并不理想。此外,索引只适用于查找操作,对于更新操作并不适用。 综上所述,索引是MySQL中的一种查询优化技术,通过在索引访问路径上对查询条件进行判断,减少数据块的读取和查询次数,从而提高查询效率。 ### 回答3: 索引是MySQL优化查询性能的一种技术,它能够通过索引提前过滤掉不符合查询条件的行,从而减少了对数据的访问量,提高了查询效率。 在传统的查询过程中,MySQL首先会根据查询条件扫描索引,找到匹配的行,然后再针对这些行到数据表中进行查找。这种方式的问题在于,对于某些情况下,索引范围的扫描可能会导致大量不符合查询条件的行被读取出来,浪费了IO资源和CPU资源。 索引的目的就是在扫描索引的过程中,就根据查询条件对索引进行过滤,将不符合条件的行排除掉。这样一来,在访问数据表之前,就减少了对不符合条件的行的读取,从而提高了查询效率。 索引的原理是在索引节点上新增一个标记位,用于标记该节点下方的所有行是否符合查询条件。当查询中存在多个索引时,MySQL会根据查询条件选择合适的索引进行索引,并根据索引扫描的速度和是否过滤掉大量行数的能力进行判断。 需要注意的是,索引并不是适用于所有情况,只有在具备一定条件下才能发挥作用。具体来说,索引主要适用于范围条件查询、多列条件查询等场景。同时,索引只在MySQL优化器认为其可行且能提高查询性能的情况下才会被使用。 总结来说,索引是MySQL中一种优化查询性能的技术,通过在扫描索引的过程中对索引进行过滤,减少不符合查询条件的行的读取,从而提高查询效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潇洒大舅哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值