MySQL Index Condition Pushdown Optimization
比如数据库中有如下表:
show create table people\G
*************************** 1. row ***************************
Table: people
Create Table: CREATE TABLE `people` (
`zipcode` varchar(16) NOT NULL,
`lastname` varchar(32) NOT NULL,
`address` varchar(32) NOT NULL,
KEY `idx_people_zipcode_lastname_address` (`zipcode`,`lastname`,`address`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci
1 row in set (0.001 sec)
我们执行如下查询:
SELECT * FROM people
WHERE zipcode='95054'
AND lastname LIKE '%etrunia%'
AND address LIKE '%Main Street%';
如果没有 index condition pushdown optimization 的话,那么执行步骤如下:
- 对比
idx_people_zipcode_lastname_address
索引中zipcode
是否能匹配,如果可以匹配,获取整个数据行; - 对比
WHERE
中的条件,看是否可以全部匹配;
而有了 index condition pushdown optimization 之后,步骤则变成了:
- 对比
idx_people_zipcode_lastname_address
索引中的zipcode
是否能匹配,同时对比WHERE
语句中,index中包含的部分,看是否可以通过; - 如果可以通过,获取整个数据行;
- 对比
WHERE
中的条件,看是否可以全部匹配;
这两者的区别就在于,是否充分利用了索引中的值,提前进行了数据的过滤。我们在 EXPLAIN
的时候,如果当前数据库查询使用了这项优化,则会在 Extra
那一列显示 Using index condition
。
ref:
更多文章
本站热门
- socks5 协议详解
- zerotier简明教程
- 搞定面试中的系统设计题
- 用peewee代替SQLAlchemy
- frp 源码阅读与分析(一):流程和概念
- Golang(Go语言)中实现典型的fork调用
- DNSCrypt简明教程
- 一个Gunicorn worker数量引发的血案
- Golang validator使用教程
- Docker组件介绍(一):runc和containerd
- Docker组件介绍(二):shim, docker-init和docker-proxy
- 使用Go语言实现一个异步任务框架
- 协程(coroutine)简介 - 什么是协程?
- SQLAlchemy简明教程
- Go Module 简明教程