本文实例讲述了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;
<?phpset_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相关内容感兴趣的读者可查看本站专题:《MySQL索引操作技巧汇总》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》

希望本文所述对大家MySQL数据库计有所帮助。

更多相关文章

  1. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  2. 《Android和PHP最佳实践》官方站
  3. android用户界面之按钮(Button)教程实例汇
  4. TabHost与RadioGroup结合完成的菜单【带效果图】5个Activity
  5. Android(安卓)UI开发第十七篇——Android(安卓)Fragment实例(Lis
  6. Android——Activity四种启动模式
  7. [android源码下载索引贴】微信+二维码那都不是事......
  8. Android布局(序章)
  9. Android发送短信方法实例详解

随机推荐

  1. Android(安卓)studio搭建helloworld案例
  2. Android(安卓)从源码分析View层次之Actio
  3. 使用Android调用LTP Cloud实现分词
  4. android 天气预报 数据的处理
  5. Android(安卓)Android(安卓)Studio 3.3
  6. android 积累一点关于fragment的知识
  7. android emulator:如何模仿mo以及sms
  8. AndroidStudio快捷键汇总
  9. 【转】Android之AsyncTask的用法
  10. Android(安卓)实现 WheelView