一文彻底理解索引下推

了解索引下推吗?二级索引取出的数据是依次回表还是一次回表?索引下推是为了什么发明的?

看完这个文章你将知道上面的问题。

索引下推的概念

MySQL5.6开始引入的一个特性,索引下推通过减少回表的次数来提高数据库的查询效率;

注意:索引下推是为了减少回表而发明的。

索引下推的产生一定围绕着回表,没有回表那就没必要产生索引下推,因为上面也说了索引下推的目的就是减少回表,而不是避免回表。(题外话:避免回表使用索引覆盖------建立覆盖索引)

索引下推的目的

索引下推的流程

实验

sql 复制代码
create table xiatui(
	id int PRIMARY Key,
	name varchar(10),
	age varchar(10),
	sex int,
	key inx_naa(name,age)
)

表中有一个二级索引

语句1:

sql 复制代码
explain
select * from xiatui where name like '%0' and age = '9802';

因为%在前面所以不会走索引,当然如果不是select * ,会使用二级索引的index。

可以看到extra=using where。这个意思就是在mysql在server层中进行了条件过滤。

语句2:

sql 复制代码
explain
select * from xiatui where name like '0%' and age = '9802';

extra=using index condition 发生了索引下推。

相关推荐
一瓢西湖水9 小时前
列式数据库-以clickHouse为例
数据库·clickhouse
Elastic 中国社区官方博客9 小时前
使用 Elastic Cloud Serverless 扩展批量索引
大数据·运维·数据库·elasticsearch·搜索引擎·云原生·serverless
liulanba9 小时前
AI Agent技术完整指南 第一部分:基础理论
数据库·人工智能·oracle
逆天小北鼻10 小时前
Oracle 服务端与客户端的核心区分要点
数据库·oracle
2501_9462429310 小时前
MPV-EASY Player (MPV播放器) v0.41.0.1
数据库·经验分享·云计算·计算机外设·github·电脑·csdn开发云
MySQL实战10 小时前
Redis 7.0 新特性之maxmemory-clients:限制客户端内存总使用量
数据库·redis
VX:Fegn089511 小时前
计算机毕业设计|基于springboot + vue校园社团管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
北亚数据恢复12 小时前
虚拟机数据恢复—ESXi虚拟机下SqlServer数据库数据恢复案例
数据库
susu108301891112 小时前
使用navicat创建事件event报错You have an error in your SQL syntax
数据库·sql
水力魔方12 小时前
武理排水管网模拟分析系统应用专题5:模型克隆与并行计算
数据库·c++·算法·swmm