mysql索引的内部实现原理_Mysql索引实现原理

一、 索引实现的数据结构

Mysql对于不同的存储引擎,索引的实现实现方式是不同的。主流的存储引擎:MyISAM和InnoDB,两种存储引擎都使用B+Tree(B-Tree的变种)作为索引结构,但是在实现方式上,却有很大的不同。下面是两种BTree数据结构:

B-Tree结构:

3c664a4fc441b9c5f634739231579b22.pngB-Tree索引数据结构

B-Tree无论是叶子结点还是非叶子结点,都含有key和一个指向数据的指针,只要找到某个节点后,就可以根据指针找到磁盘地址从而找到数据。

B+Tree结构:

d650bbeb947ceaba4877a22bae19309d.pngB+Tree索引数据结构

B+Tree所有叶子结点才有指向数据的指针。非叶子结点就是纯索引数据和主键。每个叶子结点都有指向下一个叶子结点的链接。

小结:非叶子结点存放在内存中,也叫内结点,因此,在有限的内存中, B-Tree中每个数据的指针会带来额外的内存占用,减少了放入内存的非叶子结点数;B+Tree则尽可能多地将非叶子结点放入内存中。

二、Mysql中索引实现

由于B+Tree数据结构的优势,目前mysql基本都采用B+Tree方式实现索引,下面列出了两个最常用的存储引擎的索引实现:

1、MyISAM:如下图,叶子结点的data域存放的是数据的地址:

c7d7a9e98be04c6324e3fce0db39cde3.pngMyISAM引擎中的B+Tree索引结构

上图表中共三列数据,col1为主键,表示MyISAM表的主索引示意图,在MyISAM中,主索引和辅助索引(除主键以外的其它索引)在结构上没有任何区别,只是主索引的key是唯一的,辅助索引的key可以重复。

2、InnoDB:对比MyISAM,InnoDB的主键索引与辅助索引存储方式是不同的:

主键索引:主键索引的叶子结点存放的是key值和数据,叶子结点载入内存时,数据一起载入,找到叶子结点的key,就找到了数据。

b8bd3d9a7e6d2d730cb4a043ec29d03c.pngInnodb主键索引结构

辅助索引:辅助索引的叶子结点存放的是key值和对应的记录的主键值,使用辅助索引查询,首先检索辅助索引获取主键,然后用主键在主索引中检索获取记录。

8e6c03835e7fb2fa3cb89e5f8347b1e3.pngInnodb辅助索引结构

小结:MyISAM索引叶子节点存放的是数据的地址,主键索引与辅助索引除了值得唯一性在结构上完全一样。InnoDB索引叶子节点存放的内容因索引类型不同而不同,主键索引叶子节点存放的是数据本身,辅助索引叶子节点上存放的是主键值。

今天的分享就到这里,如果喜欢我的内容,欢迎转发~~

下期见!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值