查看原文
其他

MySQL 为什么建议使用自增主键?

Java之间 2020-10-17

The following article is from 谭小谭 Author 谭小谭啊

点击上方Java之间”,选择“置顶或者星标”

你关注的就是我关心的!

作者:谭小谭

微信公众号:谭小谭(ID:tanstory)

上一篇:为何IDEA比Eclipse更好!

我们都知道表的主键一般都要使用自增 id,不建议使用业务 id ,是因为使用自增 id 可以避免页分裂。这个其实可以相当于一个结论,你都可以直接记住这个结论就可以了。

但是如果你要弄明白什么是页分裂,或者什么情况下会页分裂,这个时候你就需要对 mysql 的底层数据结构要有一定的理解了。

我这里也稍微解释一下页分裂,mysql (注意本文讲的 mysql 默认为InnoDB 引擎)底层数据结构是 B+ 树,所谓的索引其实就是一颗 B+ 树,一个表有多少个索引就会有多少颗 B+ 树,mysql 中的数据都是按顺序保存在 B+ 树上的(所以说索引本身是有序的)。

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

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

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

当往一个快满或已满的数据页中插入数据时,新插入的数据会将数据页写满,mysql 就需要申请新的数据页,并且把上个数据页中的部分数据挪到新的数据页上。

这就造成了页分裂,这个大量移动数据的过程是会严重影响插入效率的。

其实对主键 id 还有一个小小的要求,在满足业务需求的情况下,尽量使用占空间更小的主键 id,因为普通索引的叶子节点上保存的是主键 id 的值,如果主键 id 占空间较大的话,那将会成倍增加 mysql 空间占用大小。


最近热文阅读:

1、Java面试官:给Java面试者的八点建议

2、面试官:MyBatis你只写了接口为啥就能执行SQL啊?

3、面试题总结:可能是全网最好的MySQL重要知识点

4、编码神奇Lombok!搭配IDEA更爽哦!

5、面试的加分项:懂点 Nginx 反向代理与负载均衡

6、面试官 5 连问:一个 TCP 连接可以发多少个 HTTP 请求?

7、IntelliJ IDEA 2019从入门到癫狂 图文教程!

8、整理了 15 道 Spring Boot 高频面试题,看完当面霸!

9、别在 Java 代码里乱打日志了,这才是正确的打日志姿势!

关注公众号,你想要的Java都在这里

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存