MySQL 5.7和 MySQL8.0 InnoDB auto_increment 初始化的区别

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 在MySQL 5.7及之前,自动递增计数器只存于内存,重启后需通过查询确定初始值。从MySQL 8.0开始,计数器变化时写入重做日志,检查点时保存至数据字典,确保重启后能基于持久化的最大值初始化,避免查询,增强连续性和一致性。[[MySQL参考手册, 3099页]](https://dev.mysql.com/doc/refman/8.0/en/innodb-auto-increment-handling.html)

摘自:

image.png

译文如下:

在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 页

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
9月前
|
SQL 关系型数据库 MySQL
MySQL AUTO_INCREMENT 原理解析
在关系型数据库MySQL中,AUTO_INCREMENT是数据库的一个属性,该属性使得在申明了AUTO_INCREMENT的列中可以自动生成唯一的递增值。本文详细介绍了在InnoDB及MyISAM引擎中AUTO_INCREMENT的使用原理及一些容易被忽略的问题。
|
1月前
|
安全 中间件 C++
【C++运算符重载】运算符重载的艺术与实践:何时使用以及使用示例
【C++运算符重载】运算符重载的艺术与实践:何时使用以及使用示例
72 5
|
9月前
|
存储 SQL 关系型数据库
MySQL支持的复制类型及MyISAM与InnoDB的区别
MySQL支持的复制类型及MyISAM与InnoDB的区别
106 0
|
6天前
|
SQL 关系型数据库 MySQL
记一次MySQL AUTO_INCREMENT的故障
一、前言开发突然紧急的过来说,他们记录无法插入了,有报重复键错误ERROR 1062 (23000): Duplicate entry '2147483647' for key 'PRIMARY'表名和数据都是采用测试数据,结果和生产的现象是一致的二、分析测试环境为percona server 5....
10 0
|
SQL 关系型数据库 MySQL
MySQL中ENGINE=InnoDB、AUTO_INCREMENT的意思
MySQL中ENGINE=InnoDB、AUTO_INCREMENT的意思
|
SQL 关系型数据库 MySQL
MySQL 使用 AUTO_INCREMENT 关键字
MySQL 使用 AUTO_INCREMENT 关键字
103 0
|
存储 关系型数据库 MySQL
MySQL中'' ' ' NULL在Innodb存储的区别
MySQL中'' ' ' NULL在Innodb存储的区别
|
SQL 关系型数据库 MySQL
MySQL 5.7下InnoDB对COUNT(*)的优化
MySQL 5.7下InnoDB对COUNT(*)的优化
169 0
MySQL 5.7下InnoDB对COUNT(*)的优化
|
SQL 存储 关系型数据库
MYSQL INNODB主键使用varchar和int的区别
原创,如果有误请指出 今天同事讨论关于主键使用varchar和int的区别。 我现在总结的3个问题: 1、tablespace中空间浪费    当然我们知道使用varchar可能会导致辅助索引比较大,因为用到varchar可能存储的字符较多,同时    在行头也存在一个可变字段字符区域(1-2)字节    而辅助索引叶子结点毕竟都存储了主键值,这样至少会多varchar数据字节数量+1(或者2) 字节- 4(int)字节空间。
2185 0
|
MySQL 关系型数据库 PHP
mysql的auto_increment详解
转载http://blog.csdn.net/fwkjdaghappy1/article/details/7663331 auto_increment的基本特性 MySQL的中AUTO_INCREMENT类型的属性用于为一个表中记录自动生成ID功能,可在一定程度上代替Oracle,PostgreSQL等数据库中的sequence。
1557 0