1.顺序写入,避免了叶的分裂,数据写入效率好
2.缩小了表的体积,特别是相比于UUID当主键,甚至组合字段当主键时,效果更明显
3.查询效率好,原因就是我上面说到索引知识的第二点 。
4.某些情况下 , 我们可以利用自增id来统计大表的大致行数 。
5.在数据归档or垃圾数据清理时,也可方便的利用这个id去操作,效率高 。
容易出现不连续的id
有的同志会发现 , 自己的表中id值存在空洞,如类似于1、2、3、8、9、10这样,有的适合有想依赖于自增id的连续性来实现业务逻辑,所以会想方设法去修改id让其变的连续,其实,这是没有必要的 , 这一块的业务逻辑交由MySQL实现是很不理智的 , 表的记录小还好,要是表的数据量很大,修改起来就糟糕了 。那么,为什么自增id会容易出现空洞呢?
自增id的修改机制如下:
在MySQL里面,如果字段id被定义为AUTO_INCREMENT,在插入一行数据的时候,自增值的行为如下:
1. 如果插入数据时id字段指定为0、null 或未指定值,那么就把这个表当前的
AUTO_INCREMENT值填到自增字段;
2. 如果插入数据时id字段指定了具体的值,就直接使用语句里指定的值 。
根据要插入的值和当前自增值的大小关系,自增值的变更结果也会有所不同 。假设,某次要插入的值是X,当前的自增值是Y 。
1. 如果XY , 那么这个表的自增值不变;
2. 如果X≥Y,就需要把当前自增值修改为 新的自增值。
新的自增值生成算法是:从auto_increment_offset开始,以auto_increment_increment为步长 , 持续叠加,直到找到第一个大于X的值,作为新的自增值 。
Insert、update、delete操作会让id不连续 。
Delete、update:删除中间数据 , 会造成空动,而修改自增id值,也会造成空洞(这个很少) 。
Insert:插入报错(唯一键冲突与事务回滚),会造成空洞,因为这时候自增id已经分配出去了 , 新的自增值已经生成,如下面例子:
[root@localhost][test1] select * fromt;
+----+------+
| id | name |
+----+------+
|1| aaa|
|2| aaa|
|3| aaa|
|4| aaa|
+----+------+
4 rows in set (0.00 sec)
[root@localhost][test1] selectAuto_increment from information_schema.tables where table_name='t';
+----------------+
| Auto_increment |
+----------------+
|5 |
+----------------+
1 row in set (0.00 sec)
[root@localhost][test1] begin;
Query OK, 0 rows affected (0.00 sec)
[root@localhost][test1] insert intot(name) values('aaa');
Query OK, 1 row affected (0.00 sec)
[root@localhost][test1] select * fromt;
+----+------+
| id | name |
+----+------+
|1| aaa|
|2| aaa|
|3| aaa|
|4| aaa|
|5| aaa|
+----+------+
5 rows in set (0.00 sec)
[root@localhost][test1] selectAuto_increment from information_schema.tables where table_name='t';
+----------------+
| Auto_increment |
+----------------+
|6 |
+----------------+
1 row in set (0.00 sec)
[root@localhost][test1] rollback;
Query OK, 0 rows affected (0.00 sec)
[root@localhost][test1] selectAuto_increment from information_schema.tables where table_name='t';
+----------------+
| Auto_increment |
+----------------+
|6 |
+----------------+
1 row in set (0.01 sec)
[root@localhost][test1] select * fromt;
+----+------+
| id | name |
+----+------+
|1| aaa|
|2| aaa|
|3| aaa|
|4| aaa|
+----+------+
推荐阅读
- chatgpt让别人写code,怎么用chatGpt写论文
- java游戏魂斗罗源代码,c++魂斗罗源代码
- jquery怎么获得对象的父级,jquery获取当前对象的id
- 插卡路由器用网线怎么连接,插卡路由器能接电脑吗
- s函数中C语言 c语言的srand函数
- sapsavetext的简单介绍
- 苹果手机拳击格斗游戏,iphone格斗游戏
- html5滚动时间选择,html滚动设置
- c语言编写函数求和 c语言用函数求和的程序