MYSQL 回表、索引覆盖、 索引下推[通俗易懂]

MYSQL 回表、索引覆盖、 索引下推[通俗易懂]1.索引种类创建数据表&插入数据createtableuser(idint(10)auto_increment,namevarchar(30),agetinyint(4),primarykey(id),indexidx_age(age)USINGBTREE)engine=innodbcharset=utf8mb4;insertintouser(name,age)values(‘张三’,30),

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1. 索引种类

创建数据表& 插入数据

create table user(
    id int(10) auto_increment,
    name varchar(30),
    age tinyint(4),
    primary key (id),
    index idx_age (age) USING BTREE
)engine=innodb charset=utf8mb4;


insert into user(name,age) values
('张三',30),
('李四',20),
('王五',40),
('刘八',10);

聚簇索引

每个 INNODB 表 都会有一个聚簇索引 创建规则如下:

* 如果表设置了主键,则主键就是聚簇索引

* 如果表没有主键,则会默认第一个NOT NULL,且唯一(UNIQUE)的列作为聚簇索引

* 以上都没有,则会默认创建一个隐藏的row_id作为聚簇索引

聚簇索引整体是一个B+树,非叶子节点存放的是键值,叶子节点存放的是行数据,称之为数据页,这就决定了表中的数据也是聚簇索引中的一部分,数据页之间是通过一个双向链表来链接

数据存储结构简图:

MYSQL 回表、索引覆盖、 索引下推[通俗易懂]

普通索引

普通索引也叫二级索引,辅助索引, 除聚簇索引外的索引,即非聚簇索引。

InnoDB的普通索引叶子节点存储的是主键(聚簇索引)的值,而MyISAM的普通索引存储的是记录指针。

MYSQL 回表、索引覆盖、 索引下推[通俗易懂]

 2. 回表查询

执行下面sql查询

select id,name from user where age = 10;

分析查询过程,  首先通过普通索引(age) 定位 age = 10 的ID 然后通过聚集索引 查询select 字段返回结果集 , 此过程 需要扫描两次索引B+树,它的性能较扫一遍索引树更低。

3. 索引覆盖

执行下面sql查询

select id,age from user where age = 10;

可通过普通索引列(age) 就能获取SQL所需的所有列数据,无需回表,速度更快。

explain 分析:

MYSQL 回表、索引覆盖、 索引下推[通俗易懂]

 可通过Extra 是否是Using Index 判断查询是否索引覆盖

如何实现索引覆盖: 

将被查询的字段,建立到联合索引里去

哪些场景适合使用索引覆盖来优化SQL

  • 全表count查询优化 
  • 列查询回表优化

  • 分页查询

4. 索引下推

在上面数据表的基础上 添加复合索引 

 index idx_age_name (age,name)

执行下面sql查询,分析查询过程

select id,age from user where name like '张%' and age = 20;

Mysql版本 < 5.6

检索复合索引 idx_name_age  查询出所有 name 包含 “张” 的主键ID 然后通过聚簇索引判断出所有符合where子句的数据返回 ,此过程需要回表

Mysql版本 >= 5.6

检索复合索引 idx_name_age  查询所有 name 包含 “张” 的 且age =20 的数据 直接返回结果集, 无需回表

可见 索引下推在非主键索引上的优化,可以有效减少回表的次数,大大提升了查询的效率

explain 分析:

MYSQL 回表、索引覆盖、 索引下推[通俗易懂]

 Using Index Condition  使用了索引下推的表现

end!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189550.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PSCP 基本使用[通俗易懂]

    PSCP 基本使用[通俗易懂]PSCP基本使用问题:如何免密码输入,传送数据“sshpassisnotrecognized”onWindows”PSCP:是Putty的文件传输工具,用于两台电脑之间的文件传输重点:可以在命令中添加密码,不像SCP需要单独输入密码下载putty工具putty工具操作1:从本地传输文件到服务器(windowtolinux)PSCP-pw12345678C:\Users\Firmi\Desktop\test.txtroot@192.168.1.88:/root

    2025年7月14日
    2
  • 采用大杀招QEMU调试Linux内核代码

    采用大杀招QEMU调试Linux内核代码

    2022年1月17日
    44
  • 独立成分分析(ICA)

    独立成分分析(ICA)1.概念独立成分分析是从多元(多维)统计数据中寻找潜在因子或成分的一种方法.ICA与其它的方法重要的区别在于,它寻找满足统计独立和非高斯的成分。这里我们简要介绍ICA的基本概念、应用和估计原理。1.1 多元数据的线性表示统计数据处理及相关领域中的一个重要和需要长期研究的问题就…

    2022年5月17日
    47
  • DSP效果器调音教程_DSP控制器

    DSP效果器调音教程_DSP控制器1)DSP输出给5V的电路(如D/A),无需加任何缓冲电路,可以直接连接。3)的JTAG口的信号也必须为3.3V,否则有可能损坏DSP。dsp教程24。为什么要片内RAM大的DSP效率高?目前DSP发展的片内存储器RAM越来越大,要设计高效的DSP系统,就应该选择片内RAM较大的DSP。片内RAM同片外存储器相比,有以下优点:1)片内RAM的速度较快,可以保证DSP无等待运行。2)对于C2000…

    2025年8月27日
    9
  • java遍历List

    初始数据,例如DAO层返回的商品列表List,如下:List<Goods>list=goodMapper.getGoodsBySid(sid);1、迭代器遍历,方便删除元素Iterator<Goods>iterator=list.iterator();while(iterator.hasNext()){ Goodsgood=it…

    2022年4月4日
    57
  • 香农编码的matlab实现实验总结_香农编码C语言

    香农编码的matlab实现实验总结_香农编码C语言信息论与编码实验报告院系:哈尔滨理工大学荣成校区专业:电子信息工程学号:姓名:日期:2015年6月16日香农编码信息论与编码第三次实验报告一……四、实验环境MicrosoftWindows7Matlab6.5五、编码程序计算如下信源进行香农编码,并计算编码效率:XPa00.2a10.19a20.18a30.17a40……

    2022年9月10日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号