MySQL中innodb下的auto_increment处理情况
来源:互联网 发布:淘宝账号登陆首页 编辑:程序博客网 时间:2024/05/29 12:23
MySQL中innodb下的auto_increment处理情况
mysql 2010-11-26 17:40:30 阅读20 评论0 字号:大中小 订阅
如果你为一张使用了innodb引擎的表指定了一auto_increment列,那么当你不指定列地插入一些数据,而这个插入失败了的话,insert是回滚了,但是当你用show create table xxx查看auto_increment的最新值的话你会发现,auto_increment并没有回滚。那这是怎么回事呢?
在MySQL Manual中,有关于这个问题的说明:AUTO_INCREMENT Handling in InnoDB。
大概说一下。MySQL中,如果你为一张使用了innodb引擎的表指定了一auto_increment列,那么这张表会有一个auto_increment计数器,专门记录当前auto_increment的相关值,用来在insert时为auto_increment列赋值。非常重要的一点是,这个计数值是保存在内存中的,而非磁盘上。当mysql server处于运行的时候,这个计数值只会随着insert改增长,不会随着delete而减少。换句话说,auto_increment计数值永远是处于增长状态,不会减小。假设这时数据库中有100条记录,id从1到100,auto_increment计数值是101(计数值永远是下一条insert的值,也就是永远比当前auto_increment列的值大1),当我delete id=100的记录后,再insert一条语句,这条语句的id便是101,而非100.
当mysql server重新启动后,auto_increment的值就有可能会改变,上面刚开始我们说过,这个值是innodb存储在内存中的,而非磁盘上,因此刚刚启动时,当我们需要去查询auto_increment计数值时,mysql便会自动执行:
SELECT MAX(id) FROM t FOR UPDATE;
语句来获得当前auto_increment列的最大值,然后将这个值放到auto_increment计数器中。
接着只要用户不是显示地指定id列的值,auto_increment计数器值会随着每次insert而自动增长,每插入一条记录,自增1.
那么,如果我显示的指定id列的值,且指定的这个值比当前auto_increment计数器的值大,将会怎么处理呢?mysql会将这个值自增1后赋值给auto_increment计数器。
如果在一个事务中,其中有insert操作,这时auto_increment计数器随之增长,但是最后你rollback了,这时auto_increment不会随之rollback,这一点还是要注意的。
本帖原创地址:http://shanchao7932297.blog.163.com/blog/static/13636242010102654030196/
- MySQL中innodb下的auto_increment处理情况
- MySQL/InnoDB处理AUTO_INCREMENT(一)
- MySQL/InnoDB处理AUTO_INCREMENT(二)
- mysql innodb和myisam的auto_increment
- INNODB引擎下auto_increment的应用
- 关于MySQL AUTO_INCREMENT的小情况
- AUTO-INC锁和AUTO_INCREMENT在InnoDB中处理方式
- MySQL中,AUTO_INCREMENT的困惑?
- mysql中auto_increment的incrementoffset
- 14.5.5 AUTO_INCREMENT Handling in InnoDB 在InnoDB AUTO_INCREMENT处理
- 重启mysql,auto_increment的值重置(InnoDB)
- mysql中的auto_increment的问题(MyISAM,InnoDB)
- mysql如何处理auto_increment
- 不删除数据的情况下重置AUTO_INCREMENT的方法
- MyBatis 3 中,使用MySql 的AUTO_INCREMENT
- mysql中auto_increment是干什么的?
- MySQL的AUTO_INCREMENT
- MySQL的AUTO_INCREMENT
- AIDL入门
- 20个免费vpn
- C++类构造函数
- js或者JQ的focus和select失效问题和input type=file上传文件问题
- poj 2406 KMP
- MySQL中innodb下的auto_increment处理情况
- 网页导航树的简单快速美观之实现
- Visual Studio 遇到了异常,这可能是由某个扩展所致的
- 五一报警记
- 【java】java的String有时候可以用==比较的本质
- ubuntu 配置samba , 与xp共享文件
- static_cast、dynamic_cast等
- oracle 数据字典表之:DBA_TABLES
- DELPHI常用函数集及简要范例