MySQL索引下推(ICP)的简单理解与示例
前言
【MySQL索引下推(ICP)的简单理解与示例】索引下推(Index Condition Pushdown, 简称ICP)是MySQL 5.6 版本的新特性,它能减少回表查询次数,提升检索效率。
MySQL体系结构
要明白索引下推,首先要了解MySQL的体系结构:
文章图片
上图来自MySQL官方文档。
通常把MySQL从上至下分为以下几层:
- MySQL服务层:包括NoSQL和SQL接口、查询解析器、优化器、缓存和Buffer等组件。
- 存储引擎层:各种插件式的表格存储引擎,实现事务、索引等各种存储引擎相关的特性。
- 文件系统层: 读写物理文件。
索引下推案例
假设用户表数据和结构如下:
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 |
select * from user where age>20 and birthday="03-01"
由于age字段使用了范围查询,根据最左前缀原则,这种情况只能使用age字段进行范围查询,索引中的birthday字段无法使用。使用explain查看执行计划:
+------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+| id| select_type | table | type| possible_keys | key| key_len | ref| rows | Extra|+------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+|1 | SIMPLE| user| range | age_birthday| age_birthday | 4| NULL | 3| Using index condition |+------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+
可以看到虽然使用了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行记录。
- 存储引擎根据索引查找出age>20的用户id,并使用索引中的birthday字段过滤掉不符合birthday="03-01"条件的记录,最后得到id=4;
- 存储引擎到表格中取出id=4的1条记录,返回给服务层;
- 服务层过滤掉不符合birthday="03-01"条件的记录,最后返回查询结果为id=4的1行记录。
总结 到此这篇关于MySQL索引下推(ICP)的简单理解与示例的文章就介绍到这了,更多相关MySQL索引下推(ICP)内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复
- 15、IDEA学习系列之其他设置(生成javadoc、缓存和索引的清理等)
- mysql|InnoDB数据页结构
- mysql中视图事务索引与权限管理
- MYSQL主从同步的实现
- MySQL数据库的基本操作
- javaweb|基于Servlet+jsp+mysql开发javaWeb学生成绩管理系统
- Python3|Python3 MySQL 数据库连接