0

0

SQL 页分裂是如何发生的?

冰川箭仙

冰川箭仙

发布时间:2026-01-20 17:12:01

|

905人浏览过

|

来源于php中文网

原创

页分裂是数据库为维持B+树有序性与平衡性,在目标页满且插入点不在末尾时触发的自动拆分机制;需分配新页、迁移约一半数据、更新父节点并写入日志,导致写放大、锁争用、碎片升高和索引层级膨胀。

sql 页分裂是如何发生的?

页分裂是数据库在插入或更新数据时,因目标数据页空间不足而触发的自动拆分机制,核心目的是维持B+树索引的有序性与平衡性。

页分裂发生的前提条件

InnoDB默认页大小为16KB(SQL Server常用8KB),页内数据按主键顺序排列。当执行插入或变长字段更新操作时,数据库会先定位到目标页,再检查剩余空间是否足够容纳新记录。只有在目标页已满(或剩余空间小于新记录所需空间)且插入位置不在页末尾时,才会触发页分裂。

  • 页满但插入点在末尾(如自增ID追加):通常不迁移数据,只分配新页——这是低开销的“插入点分裂”
  • 页满且插入点在中间(如随机ID、倒序时间戳):必须拆分原页,迁移部分数据到新页
  • 更新导致行变大(如TEXT字段增长):原页放不下,也可能引发内部分裂

页分裂的具体执行过程

以最常见的叶子节点分裂为例:

宽维企业网站管理系统4.0
宽维企业网站管理系统4.0

宽维企业网站管理系统功能说明宽维系列网站管理系统全面免费,个人和商业应用均免费。宽维企业网站管理系统是基于Php+MySql技术开发的企业电子商务平台,全后台操作,无需学习网页制作等知识。前台智能生成页面,可以方便地在线管理、维护、更新您的企业网站。宽维企业网站管理系统安装简单快捷,5分钟就可以安装完成。1 栏目管理方便灵活:可以发布和管理您需要的任何内容的个性栏目。内置数十个功能发布模型,并可以

下载
  • 系统定位到应插入的叶子页(例如存储ID 1500–1600的页),发现已无足够空闲空间
  • 分配一个全新空白页(如Page2),将原页(Page1)中约一半数据(通常是后半键值范围,如1550–1600)迁移到新页
  • 根据新记录键值决定插入位置:若插入ID=1550,则放入新页;若插入ID=1525,则留在原页
  • 更新父节点(非叶子页),添加指向新页的指针;若父节点也满,则递归向上分裂,极端情况会新增根节点、提升树高
  • 重写页头/页尾元数据,并同步写入Redo Log,确保崩溃可恢复

为什么必须迁移“约一半”数据?

这不是随意选择,而是B+树结构的要求:

  • 保证所有叶子节点处于同一层级,维持O(log n)查询效率
  • 避免新页立即再次填满,两个页都保留合理空闲空间,延缓下一次分裂
  • 保持键值顺序连续:原页保留前半段(如1500–1549),新页承接后半段(1550–1600),逻辑链表可正确串联

页分裂带来的实际影响

它不只是“多建一个页”,而是一系列资源消耗操作:

  • 写放大:一次插入可能引发多次物理写入(原页读、新页写、父节点更新、日志写入)
  • 锁与闩争用:分裂期间需获取页面级排他锁(X lock)和latch,阻塞并发读写
  • 碎片升高:分裂后页平均填充率下降,磁盘I/O效率降低,avg_page_space_used_in_percent明显低于90%
  • 索引层级膨胀:频繁上层分裂可能导致B+树变高,增加每次查询的路径长度

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

683

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

358

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

677

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

575

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

417

2024.04.29

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 12.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号