mysql中聚簇索引的页分裂原理是什么

33次阅读
没有评论

共计 1404 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家介绍 mysql 中聚簇索引的页分裂原理是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

聚簇结构的特点:

根据主键查询条目时, 不用回行 (数据就在主键节点下)

如果碰到不规则数据插入时, 造成频繁的页分裂

为什么会产生页分裂?

这是因为聚簇索引采用的是平衡二叉树算法,而且每个节点都保存了该主键所对应行的数据,假设插入数据的主键是自增长的,那么根据二叉树算法会很快的把该数据添加到某个节点下,而其他的节点不用动;但是如果插入的是不规则的数据,那么每次插入都会改变二叉树之前的数据状态。从而导致了页分裂。

测试:

创建 2 张表

create table t8(
id int primary key,
c1 varchar(500),
c2 varchar(500),
c3 varchar(500),
c4 varchar(500),
c5 varchar(500),
c6 varchar(500)
) engine innodb charset utf8;
create table t9(
id int primary key,
c1 varchar(500),
c2 varchar(500),
c3 varchar(500),
c4 varchar(500),
c5 varchar(500),
c6 varchar(500)
) engine innodb charset utf8;

写一个 php 脚本,用于插入 1W 条无规则的主键数据和 1W 条规则的主键数据,来看看区别。

?php
set_time_limit(0);
$conn = mysql_connect( localhost , root , 1234 
mysql_query( use test; 
// 自增长主键
$str = str_repeat(a , 500);
$startTime = microtime(true);
for($i=1;$i =10000;$i++){ mysql_query( insert into t8 values($i, $str , $str , $str , $str , $str , $str) 
$endTime = microtime(true);
echo $endTime-$startTime. br/ 
// 无序的主键
$arr = range(1, 10000);
shuffle($arr);
$startTime = microtime(true);
foreach($arr as $i){ mysql_query( insert into t9 values($i, $str , $str , $str , $str , $str , $str) 
$endTime = microtime(true);
echo $endTime-$startTime. br/

测试结果图

mysql 中聚簇索引的页分裂原理是什么

1W 条规则的数据:998 秒 = 16 分钟
1W 条不规则的数据:1939 秒 = 32 分钟

结论:

聚簇索引的主键值, 应尽量是连续增长的值, 而不是要是随机值, (不要用随机字符串或 UUID),否则会造成大量的页分裂与页移动。在使用 InnoDB 的时候最好定义成:

id int unsigned primary key auto_increment

关于 mysql 中聚簇索引的页分裂原理是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1404字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)