在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

MySQL主键自增的原因

93次阅读
没有评论

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

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

MySQL 主键自增的原因?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是丸趣 TV 小编给大家带来的参考内容,让我们一起来看看吧!

InnoDB 引擎表的特点

1、InnoDB 引擎表是基于 B + 树的索引组织表(IOT)

关于 B + 树

MySQL 主键自增的原因

B+ 树的特点:

所有关键字都出现在叶子结点的链表中(稠密索引),且链表中的关键字恰好是有序的;

不可能在非叶子结点命中;

非叶子结点相当于是叶子结点的索引 (稀疏索引),叶子结点相当于是存储(关键字) 数据的数据层;

2、如果我们定义了主键(PRIMARY KEY),那么 InnoDB 会选择主键作为聚集索引、如果没有显式定义主键,则 InnoDB 会选择第一个不包含有 NULL 值的唯一索引作为主键索引、如果也没有这样的唯一索引,则 InnoDB 会选择内置 6 字节长的 ROWID 作为隐含的聚集索引(ROWID 随着行记录的写入而主键递增,这个 ROWID 不像 ORACLE 的 ROWID 那样可引用,是隐含的)。

3、数据记录本身被存于主索引(一颗 B +Tree)的叶子节点上。这就要求同一个叶子节点内(大小为一个内存页或磁盘页)的各条数据记录按主键顺序存放,因此每当有一条新的记录插入时,MySQL 会根据其主键将其插入适当的节点和位置,如果页面达到装载因子(InnoDB 默认为 15/16),则开辟一个新的页(节点)

4、如果表使用自增主键,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的页

5、如果使用非自增主键(如果身份证号或学号等),由于每次插入主键的值近似于随机,因此每次新纪录都要被插到现有索引页得中间某个位置,此时 MySQL 不得不为了将新记录插到合适位置而移动数据,甚至目标页面可能已经被回写到磁盘上而从缓存中清掉,此时又要从磁盘上读回来,这增加了很多开销,同时频繁的移动、分页操作造成了大量的碎片,得到了不够紧凑的索引结构,后续不得不通过 OPTIMIZE TABLE 来重建表并优化填充页面。

综上总结,如果 InnoDB 表的数据写入顺序能和 B + 树索引的叶子节点顺序一致的话,这时候存取效率是最高的,也就是下面这几种情况的存取效率最高:

使用自增列 (INT/BIGINT 类型) 做主键,这时候写入顺序是自增的,和 B + 数叶子节点分裂顺序一致;

该表不指定自增列做主键,同时也没有可以被选为主键的唯一索引(上面的条件),这时候 InnoDB 会选择内置的 ROWID 作为主键,写入顺序和 ROWID 增长顺序一致;

除此以外,如果一个 InnoDB 表又没有显示主键,又有可以被选择为主键的唯一索引,但该唯一索引可能不是递增关系时(例如字符串、UUID、多字段联合唯一索引的情况),该表的存取效率就会比较差。

感谢各位的阅读!看完上述内容,你们对 MySQL 主键自增的原因大概了解了吗?希望文章内容对大家有所帮助。如果想了解更多相关文章内容,欢迎关注丸趣 TV 行业资讯频道。

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计1242字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 欧美交换配乱吟粗大视频 | 免费看一级 | 好吊妞人成视频在线观看强行 | 在线视频观看一区 | 成人综合婷婷国产精品久久免费 | 国产午夜手机精彩视频 | 黑巨茎大战俄罗斯美女 | 日本毛片在线看 | 狠狠噜天天噜日日噜av | 免费国产va在线观看视频 | 四虎影院地址 | 疯狂撞击丝袜人妻 | 日韩丰满少妇无码内射 | 天天干亚洲 | 国产成人亚洲影视在线 | 国产高清在线精品一区免费97 | 国产交换配乱婬视频 | 一本色道久久综合亚洲精品 | 亚洲一级免费视频 | 久久久久久伊人高潮影院 | 色爱无码av综合区 | 亚洲国产美女在线观看 | 91网址在线播放 | 亚洲a级大片 | 国产资源网 | 青青青青青青在线精品视频 | a级毛片免费观看在线播放 a级毛片免费看 | 成人在线免费播放 | 日韩中文字幕电影 | 国产欧美曰韩一区二区三区 | 妞干网免费在线观看 | 99国产情在线视频 | 亚洲av无码久久精品蜜桃 | 高清日韩在线 | 亚洲日韩精品射精日 | 黄色毛片在线播放 | 亚洲国产一区二区三区最新 | 国产福利在线观看精品 | 美女黄网页 | 青青青免费网站在线观看 | 人妻无码一区二区不卡无码av |