innodb_autoinc_lock_mode 下自增id不连续的原因
来源:互联网 发布:广讯通软件下载 编辑:程序博客网 时间:2024/06/09 17:37
一、问题复现
文件/tmp/data.sql中两列,每列一个数字1;
输入
CREATE TABLE `t` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`k` int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
load data infile '/tmp/data.sql' into table t(k);
show create table t;
结果:
CREATE TABLE `t` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`k` int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8
二、原因分析
我们知道在5.1.22在之后,InnoDB为了解决自增主键锁表的问题,引入了参数innodb_autoinc_lock_mode。这个值为0时,每次申请自增主键时需要锁表。
这个参数的默认值是1,设为此值时,每次会“预申请”多余的id(handler.cc: compute_next_insert_id),而insert执行完成后,会特别将这些预留的id空出,动作就是特意将预申请后的当前最大id回写到表中(dict0dict.c:dict_table_autoinc_update_if_greater)。
三、简单计算预留
注意这个预留的策略是“不够时多申请几个”, 实际执行中是分步申请。至于申请几个,是由当时“已经插入了几条数据N”决定的。当auto_increment_offset=1时,预申请的个数是 N-1。
所以会发现,当data.sql中只有一行时,你看不到这个现象,并不预申请。
而当有两行时(如文章开头的例子),则需要。多申请的数目为1,因此执行后的自增值为4 (1+2+1)。
若data.sql中有三行呢?由于执行第三行的id已经在执行第二行时预留了,所以直接使用,结果的自增值仍为4。
后续的就类推了,可自行分析下。
实际insert行
自增id增加值
2、3
3
4、5、6、7
7
8~15
15
from : http://dinglin.iteye.com/blog/1279536
预分配的策略是首先分配1,如果在SQL的执行过程中用尽,那么乘2;如果再用尽,那么再乘2; 也就是1,2,4,8...
其它那些普通的场景,我补充一下: http://whitesock.iteye.com/blog/1329857
- innodb_autoinc_lock_mode 下自增id不连续的原因
- 解决自增id不连续的问题
- 查找SQL Server自增ID不连续记录
- 往mysql中插入 自增id不连续(曾经的坑)
- 往mysql中插入 自增id不连续(曾经的坑)
- mysql innodb 自增主键与innodb_autoinc_lock_mode
- mysql 自增长 innodb_autoinc_lock_mode
- mysql数据库删除数据后,数据自增id断点不连续
- Mysql实现数据的不重复写入(insert if not exists)以及新问题:ID自增不连续的解答
- Mysql实现数据的不重复写入(insert if not exists)以及新问题:ID自增不连续的解答
- Mysql实现数据的不重复写入(insert if not exists)以及新问题:ID自增不连续的解答
- Mysql实现数据的不重复写入(insert if not exists)以及新问题:ID自增不连续的解答
- 不使用框架的情况下 如何得到刚插入的数据(ID自增)
- 在sql200中取指定行说的数据(以自增字段id作为主键,注意id 可能不连续)
- select id from table 如何找出不连续的id..
- Mysql 查询不连续ID
- WordPress 3.0版本ID不连续的解决办法
- wordpress文章ID不连续显示问题的完美解决
- 嵌入式 笔试题(第一天)
- 符号常量
- C++_字符串类型
- poj 1837 DP
- C++_const限定修饰符
- innodb_autoinc_lock_mode 下自增id不连续的原因
- Linux环境下段错误的产生原因及调试方法小结
- Common Lisp 符号计算引论第九章练习——画一元函数图像
- C++_引用类型
- POJ——1258(最小生成树)
- 设置Frame为全屏幕
- 自动化测试框架相关资料下载
- 指针理解
- 未解决之问题