专注于分布式,性能优化,代码之美

mysql学习笔记-索引

学习mysql 笔记  https://www.cnblogs.com/lisq/p/12634457.html

mysql索引分类

1.主键索引,聚集索引:叶子节点存储的是数据行,

2.非主键索引,非聚集索引:叶子节点存储的是对应的主键值

主键索引,默认是主键,如果没有主键,mysql会自动生成一个字段作为聚聚索引。

聚簇索引默认是主键,如果表中没有定义主键,InnoDB 会选择一个唯一的非空索引代替。如果没有这样的索引,InnoDB 会隐式定义一个主键来作为聚簇索引。
因为B+TREE的原因,最好使用连续的整数字段,更好确定查找访问范围

回表

根据上面的索引结构说明,主键索引和普通索引的查询区别

  • 如果语句是 select * from T where ID=500,即主键查询方式,则只需要搜索 ID 这棵 B+ 树;
  • 如果语句是 select * from T where k=5,即普通索引查询方式,则需要先搜索 k 索引树,得到 ID 的值为 500,再到 ID 索引树搜索一次。这个过程称为回表

覆盖索引

如果执行的语句是 select ID from T where k between 3 and 5,这时只需要查 ID 的值,而 ID 的值已经在 k 索引树上了,因此可以直接提供查询结果,不需要回表。也就是说,在这个查询里面,索引 k 已经“覆盖了”我们的查询需求,我们称为覆盖索引。

索引下推

索引下推是MySQL5.6版本推出的优化手段
默认是开启的,可以通过下面命令关闭

SET optimizer_switch = 'index_condition_pushdown=off';

假如有一下SQL,不通的执行过程,如下图表示

index(name,age)
mysql> select * from tuser where name like '张%' and age=10 and ismale=1;

可以看到,无索引下推是,每次都需要回表查询,而下推的是在先过滤好结果集,回表拿select * 的数据

383bb1758fe63222df3e77351a5833e9.png
无索引下推
55d51dfd12aa0cf3b4b6a31a117377f4.png
有索引下推

posted on   xiaohouye  阅读(48)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
今日之劳累是为了铸造明日之辉煌,不管年龄多少,都无法阻挡我对软件艺术的追求!
点击右上角即可分享
微信分享提示