Mysql-InnoDB索引03:B+树索引

通过上一节的讲解,我们已经可以在一个页中通过id(主键值)快速查找到一条记录了,但是如果一张表很大,存储在不同的页中,如何在这些页中快速查找到一条记录呢(通过主键值)?这是本篇文章要解决的问题.废话不多说,上车.

1. 为页面创建目录

我们可以通过为页面创建目录的方式来快速查找到一个页面.创建方法为:

  1. 让下一个数据页中用户主键的值都要大于本页
    2.每页对应一个目录项, 目录项分两部分,key为该页最小主键值,value为指向该页的指针.
    一个简单的页面目录如下图所示:
    在这里插入图片描述
    如果我们想要查找id=220的用户记录,首先通过二分查找
    l=1 h=4–>m=3
    l=3 h=4---->h-l=1 220>key(h),所以在最后一页
    然后再页中,通过对目录项的二分查找找到记录所在的组
    最后遍历该组,就能找到id=220的用户记录

2.索引

上面介绍的页面记录就是一个简化版的索引.mysql设计人员把上面的,每个页面目录项看做一条记录,页存储在页面中,目录项记录只有主键值和页面编号两项(相当于表中只有两列),record_type=1
在这里插入图片描述

3. 插入数据的操作

4.删除数据操作

5.查找数据操作

6. 聚簇索引

聚簇索引是以主键值建立的索引,叶子节点存储的是完整的用户记录.二级索引是以其它列的值建立的索引(可能存在重复值)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

弈师亦友

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

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

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

打赏作者

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

抵扣说明:

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

余额充值