摘自:
译文如下:
在MySQL 5.7及更早版本中,自动递增计数器存储在主内存中而非磁盘上。为了在服务器重启后初始化一个自动递增计数器,在包含AUTO_INCREMENT列的表中首次插入数据时,InnoDB会执行等效于以下SQL语句的操作:
SELECT MAX(ai_col) FROM table_name FOR UPDATE;
而在MySQL 8.0版本中,这一行为发生了变化。当前的最大自动递增计数器值每当发生变化时会被写入重做日志,并且在每次检查点时保存到数据字典中。这些改变使得当前最大自动递增计数器值在服务器重启后仍能保持持久性。
在正常关闭后的服务器重启过程中,InnoDB会使用数据字典中存储的当前最大自动递增值来初始化内存中的自动递增计数器。这样一来,在MySQL 8.0版本中,即使服务器重启,也能确保自动递增计数器能够基于数据字典中持久化的当前最大值进行初始化,无需再通过查询来确定上次使用的值。这种改进有助于在服务器重启后保持自动递增值的连续性和一致性。
摘自Mysql参考手册 3099 页