mysql使用数字作为主键_mysql innodb为什么建议使用自增数字作为主键?

本文探讨了MySQL InnoDB引擎中,为何建议使用有序的自增ID作为主键。自增ID可以提高范围查询、排序和扫描表的效率,避免页分裂导致的插入效率下降。同时,较小的主键占用空间能减少存储需求和IO次数。因此,选择合适的主键设计对于数据库性能至关重要。
摘要由CSDN通过智能技术生成

7cb2767735cb120652ba90133f6ac927.png

1.建议使用有序的自增ID作为主键

bff8498f66bdf340fd1e20d2ccca1e86.png

MySQL InnoDB 引擎底层数据结构是 B+ 树,所谓的索引其实就是一颗 B+ 树,一个表有多少个索引就会有多少颗 B+ 树,mysql 中的数据都是按顺序保存在 B+ 树叶子节点上的(所以说索引本身是有序的)。

主要目的有三个:

提高范围查询效率;

增加排序效率;

提高扫表能力,顺序访问。

mysql 在底层又是以数据页为单位来存储数据的,一个数据页大小默认为 16k,当然你也可以自定义大小,也就是说如果一个数据页存满了,mysql 就会去申请一个新的数据页来存储数据。

如果主键为自增 id 的话,mysql 在写满一个数据页的时候,直接申请另一个新数据页接着写就可以了。

如果主键是非自增 id,为了确保索引有序,mysql 就需要将每次插入的数据都放到合适的位置上。

当往一个快满或已满的数据页中插入数据时,新插入的数据会将数据页写满,mysql 就需要申请新的数据页,并且把上个数据页中的部分数据挪到新的数据页上。这就造成了页分裂,这个大量移动数据的过程是会严重影响插入效率的。

2.在满足业务需求的情况下,尽量使用占空间更小的主键

主键占用空间越大,每个页存储的主键个数越少,路树就越少,B+树的深度会边长,导致IO次数会变多。

普通索引的叶子节点上保存的是主键 id 的值,如果主键 id 占空间较大的话,那将会成倍增加 mysql 空间占用大小。

mysql innodb为什么建议使用自增数字作为主键?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值