如果表有一个自增(auto-increment)列,那么 InnoDB 表处理系统将它的数据字典中包含一个特别的计数器用以记录自增列的下一个列值。 自增计数器只放于主存中,而不是放在磁盘中。
InnoDB 使用下列规则初始化自增计数器。数据库启动后,当用户第一次向表 T
插入数据或运行 SHOW TABLE STATUS
来显示表 T
时,InnoDB 将执行
SELECT MAX(auto-inc-column) FROM T FOR UPDATE,
同时将所得值加 1 现填入字段并记录表的自增记录器。如果表是空的则将值赋为 1 。注意在这个初始化过程中将为表加一个读锁(a normal x-locking read),这个锁将一直持续到事务处理结束。
InnoDB 为一个新建立的表以同样的方式建立自增计数器。
如果为一个自增列特别指定值 0 ,那么 InnoDB 将视为未为该列指定值而将该列赋于新值。
在自增计数器初始化后,在自增列中插入一个明确指定的新值 ,并且该值大于当前计数值,那么计数器将被设置为新的指定值。如果用户没有明确为它指定一个值,InnoDB 将自增计 数器,并将新值赋于自增列。
当访问自增计数器时,InnoDB 将使用一个特殊的表级锁定( AUTO-INC
lock ),锁将一直保持到当前 SQL 语句的运行结束,而不是线程的结束。特殊的锁释放策略被引入是为了改善向有自增字段的表中插入数据的并发性能。两个事务处理不能在同一张表上建立AUTO-INC
锁。
注意如果事务从自增计数器中取值,那么当事务回滚时在自增列顺序上可能会产生空隙。
如果给一个自增字段指定一个无效值或值比定义的整型类型最大值域还大,那么自增机制 的状态将无法预知。