java面经のMySQL索引的理解(主键索引和二级索引)

本文深入探讨了MySQL中的索引类型,尤其是主键索引(一级索引)和二级索引。文章阐述了B树和B+树的结构及其在索引查询中的优势,强调了B+树在范围查询和全表扫描的效率。同时,解释了InnoDB和MyISAM存储引擎在数据分布上的区别,以及聚集索引对于数据存储和查询性能的影响。

MySQL索引的理解(主键索引和二级索引)

备注:一和二体现了主次和先后关系,聚焦和非聚焦体现不出来,
我建议称为:“一级索引”和“二级索引”。

1、一级索引
索引和数据存储在一起,都存储在同一个B+tree中的叶子节点。一般主键索引都是一级索引。

2、二级索引
二级索引树的叶子节点存储的是主键而不是数据。也就是说,在找到索引后,得到对应的主键,再回到一级索引中找主键对应的数据记录。

 索引是一种用于快速查询行的数据结构,就像一本书的目录就是一个索引,如果想在一本书中找到某个主题,
 一般会先找到对应页码。在mysql中,存储引擎用类似的方法使用索引,先在索引中找到对应值
 然后根据匹配的索引记录找到对应的行。

我们首先了解一下索引的几种类型和索引的结构。

索引类型

B树
大多数存储引擎都支持B树索引。b树通常意味着所有的值都是按顺序存储的,并且每一个叶子也到根的距离相同。
B树索引能够加快访问数据的速度,因为存储引擎不再需要进行全表扫描来获取数据。
下图就是一颗简单的B树。

在这里插入图片描述
B树的查询流程:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿杰同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值