什么是页分裂?insert 操作对 B+ 树结构的改变是什么样的?

什么是页分裂?

如果我们使用非自增主键,由于每次插入主键的索引值都是随机的(比如 UUID),因此每次插入新的数据时,就可能会插入到现有数据页中间的某个位置,这将不得不移动其它数据来满足新数据的插入,甚至需要从一个页面复制数据到另外一个页面,我们通常将这种情况称为页分裂。

页分裂还有可能会造成大量的内存碎片,导致索引结构不紧凑,从而影响查询效率。

举个例子,假设某个数据页中的数据是1、5、9、10,且数据页满了,现在准备插入一个数据6,则需要把数据页分割为两个数据页:

在这里插入图片描述

出现页分裂时,需要将一个页的记录移动到另外一个页,性能会受到影响,同时页空间的利用率下降,造成存储空间的浪费。

而如果记录是顺序插入的,例如插入数据11,则只需开辟新的数据页,也就不会发生页分裂:

在这里插入图片描述

因此,在使用 InnoDB 存储引擎时,如果没有特别的业务需求,建议使用自增字段作为主键。

insert 操作对 B+ 树结构的改变是什么样的?

  • 如果我们使用主键是顺序递增,那么每次插入的新数据就会顺序插入到叶子节点最右边的节点里,如果该页面满了,就会自动开辟一个新页面,将新数据插入到新页面。因为每次插入一条新记录,都是追加操作,不需要重新移动数据,因此这种插入数据的方法效率非常高。

  • 如果我们使用主键不是顺序递增,由于每次插入主键的索引值都是随机的,因此每次插入新的数据时,就可能会插入到现有数据页中间的某个位置,这时候为了保证B+ 树的有序性,要移动其它数据来满足新数据的插入如果该页面满了,就发生页分裂,这时候要从一个页面复制数据到另外一个页面,目的是保证后一个数据页中的所有行主键值比前一个数据页中主键值大,页分裂可能会造成大量的内存碎片,导致索引结构不紧凑,从而影响查询效率。

所以,我们在设计主键的时候,最好采用自增的方式,或者顺序递增主键值。另外,主键字段的长度不要太大,因为主键字段长度越小,意味着二级索引的叶子节点越小(二级索引的叶子节点存放的数据是主键值),这样二级索引占用的空间也就越小。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
B树和B+树都是用于组织和管理数据的树形数据结构,但它们在结构特性和用途上有所不同。以下是它们之间的主要区别: B树: 1. B树是一种自平衡的树,这意味着它能在保持数据有序的同时,提供有效的搜索、插入和删除操作。B树的每个内部节点可以保存多个关键字以及指向子树的链接。 2. B树只有一个根节点,而且除了叶子节点外,所有的节点都是关键字及其指针的列表。每个节点的大小都有限制,以保证树的高度不超过一定值,以提高搜索效率。 3. 由于B树的内部节点可能包含大量的关键字,因此插入和删除操作可能需要跨越多个节点。为了解决这个问题,B树允许分裂和合并操作,以保持树的平衡。 B+树: 1. B+树也是一种自平衡的树,但它与B树的主要区别在于叶子节点上。B树的叶子节点是混合的,可以包含关键字和指针,而B+树的叶子节点仅包含键值和指向相关记录的指针。 2. B+树的叶子节点之间通过共同的关键字建立索引,使得查询可以更高效地通过关键字定位到相应的叶子节点集合。这使得它特别适合用于磁盘上的存储和搜索。 3. 由于叶子节点只包含键值和指针,所以B+树的内部节点可以存储更多的键值,从而减少了搜索时需要访问的叶子节点数量。这有助于提高搜索效率。 选择B+树作为InnoDB的底层数据结构的原因: InnoDB是MySQL数据库的核心存储引擎之一,它使用B+树作为其底层数据结构的主要原因有: 1. 高效搜索和查询:由于B+树的结构特性,它能够提供高效的搜索和查询操作。这对于需要频繁查询和搜索的大量数据的系统来说非常重要。 2. 磁盘友好:由于B+树的叶子节点只包含键值和指针,它更适合在磁盘上进行存储和搜索。这使得InnoDB能够更好地利用磁盘I/O性能,从而提高查询性能。 3. 顺序访问:由于B+树的叶子节点之间通过共同的关键字建立索引,它支持顺序访问操作。这对于需要按特定顺序访问数据的场景(如排序、分组等)非常有用。 4. 稳定性和可扩展性:由于B+树的结构稳定,且能够通过增加新的叶子节点来扩展存储容量,它适合于大规模数据的存储和检索。 综上所述,B+树作为InnoDB的底层数据结构提供了高效的搜索、查询、顺序访问和可扩展性等优势,使其成为适合用于处理大量数据的数据库存储引擎的理想选择。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值