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/