mysql聚簇索引的页分裂原理实例分析
作者:webbc 时间:2024-01-15 00:58:47
本文实例讲述了mysql聚簇索引的页分裂。分享给大家供大家参考,具体如下:
在MySQL中,MyISAM采用的是非聚簇索引的,InnoDB存储引擎是采用聚簇索引的。
聚簇结构的特点:
根据主键查询条目时,不用回行(数据就在主键节点下)
如果碰到不规则数据插入时,造成频繁的页分裂
为什么会产生页分裂?
这是因为聚簇索引采用的是平衡二叉树算法,而且每个节点都保存了该主键所对应行的数据,假设插入数据的主键是自增长的,那么根据二叉树算法会很快的把该数据添加到某个节点下,而其他的节点不用动;但是如果插入的是不规则的数据,那么每次插入都会改变二叉树之前的数据状态。从而导致了页分裂。
测试:
创建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/>';
测试结果图
1W条规则的数据:998秒 = 16分钟
1W条不规则的数据:1939秒 = 32分钟
结论:
聚簇索引的主键值,应尽量是连续增长的值,而不是要是随机值, (不要用随机字符串或UUID),否则会造成大量的页分裂与页移动。在使用InnoDB的时候最好定义成:
id int unsigned primary key auto_increment
希望本文所述对大家MySQL数据库计有所帮助。
来源:https://blog.csdn.net/baochao95/article/details/61924952
标签:mysql,聚簇索引
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python把一个字符串切开的实例方法
2022-07-10 21:52:17
Python基于jieba, wordcloud库生成中文词云
2022-12-24 06:31:04
![](https://img.aspxhome.com/file/2023/2/114522_0s.jpg)
Python实现完全数的示例详解
2021-11-21 20:09:30
利用后缀表达式(逆波兰式)算24点的JavaScript版算法
2010-01-23 10:57:00
CSS框架/命名/规则 注意要点
2008-06-03 13:07:00
asp如何定义参数?
2010-05-16 15:20:00
python“静态”变量、实例变量与本地变量的声明示例
2021-11-16 23:17:28
ASP 下载时重命名已上传文件的新下载文件名的实现代码
2012-11-30 20:33:45
Pytorch中torch.argmax()函数使用及说明
2021-11-24 14:49:31
![](https://img.aspxhome.com/file/2023/4/128224_0s.png)
php遍历目录与文件夹的多种方法详解
2024-05-02 17:14:33
利用python实现全屏爱心雨向喜欢的人表白
2022-05-29 22:32:14
![](https://img.aspxhome.com/file/2023/4/127644_0s.png)
MySQL中索引的优化的示例详解
2024-01-26 21:31:25
![](https://img.aspxhome.com/file/2023/4/108884_0s.png)
python-opencv-cv2.threshold()二值化函数的使用
2022-12-31 23:00:12
![](https://img.aspxhome.com/file/2023/2/92522_0s.png)
Python实现简单登录验证
2023-04-30 15:39:11
python调用文字识别OCR轻松搞定验证码
2023-02-20 17:10:54
![](https://img.aspxhome.com/file/2023/4/89044_0s.png)
Python生成器常见问题及解决方案
2023-01-23 19:09:43
python scrapy爬虫代码及填坑
2022-06-04 01:01:36
![](https://img.aspxhome.com/file/2023/9/98979_0s.png)
python 包之 Pillow 图像处理教程分享
2022-02-22 01:22:48
善用用户反馈——浅谈用户反馈数据的处理
2010-07-09 16:58:00
![](https://img.aspxhome.com/file/UploadPic/20107/9/customer-support-banner-35s.jpg)
【启发】不用循环计算1到100的和
2009-03-04 12:16:00