MySQL 8.0特性-自增变量的持久化

news/2024/11/15 11:35:24/

MySQL 8.0特性-自增变量的持久化

在MySQL 8.0之前,自增主键AUTO_INCREMENT的值如果大于max(primary key)+1,在MySQL重启后,会重置AUTO_INCREMENT=max(primary key)+1,这种现象在某些情况下会导致业务主键冲突或者其他难以发现的问题。 下面通过案例来对比不同的版本中自增变量是否持久化。

MySQL5.7测试

在MySQL 5.7版本中,测试步骤如下: 创建的数据表中包含自增主键的id字段,语句如下:

CREATE TABLE test1(
id INT PRIMARY KEY AUTO_INCREMENT
);
-- 插入4个空值,执行如下:
INSERT INTO test1
VALUES(0),(0),(0),(0);-- 查询数据表test1中的数据,结果如下:
mysql> SELECT * FROM test1;
+----+
| id |
+----+
| 1 |
| 2 |
| 3 |
| 4 |
+----+
4 rows in set (0.00 sec)-- 删除id为4的记录,语句如下:
DELETE FROM test1 WHERE id = 4;-- 再次插入一个空值,语句如下:
INSERT INTO test1 VALUES(0);-- 查询此时数据表test1中的数据,结果如下:
mysql> SELECT * FROM test1;
+----+
| id |
+----+
| 1 |
| 2 |
| 3 |
| 5 |
+----+
4 rows in set (0.00 sec)
-- 从结果可以看出,虽然删除了id为4的记录,但是再次插入空值时,并没有重用被删除的4,而是分配了5。
-- 删除id为5的记录
DELETE FROM test1 where id=5;

重启数据库

service mysql stop
service mysql start

继续插入空值,然后再次查询数据表test1中的数据,结果如下:

mysql> INSERT INTO test1 values(0);
Query OK, 1 row affected (0.00 sec)mysql> select * from test1;
+----+
| id |
+----+
|  1 |
|  2 |
|  3 |
|  4 |
+----+
4 rows in set (0.00 sec)

从结果可以看出,新插入的0值分配的是4,按照重启前的操作逻辑,此处应该分配6。出现上述结果的主要原因是自增主键没有持久化。 在MySQL 5.7系统中,对于自增主键的分配规则,是由InnoDB数据字典内部一个 计数器 来决定的,而该计数器只在 内存中维护 ,并不会持久化到磁盘中。当数据库重启时,该计数器会被初始化。

MySQL 8.0测试

上述测试步骤最后一步的结果如下:

mysql> select * from test1;
+----+
| id |
+----+
|  1 |
|  2 |
|  3 |
|  6 |
+----+
4 rows in set (0.00 sec)

从结果可以看出,自增变量已经持久化了。

MySQL 8.0将自增主键的计数器持久化到 重做日志中。每次计数器发生改变,都会将其写入重做日志中。如果数据库重启,InnoDB会根据重做日志中的信息来初始化计数器的内存值。


http://www.ppmy.cn/news/1547189.html

相关文章

leetcode61. Rotate List

Given the head of a linked list, rotate the list to the right by k places. 给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。 Input: head [1,2,3,4,5], k 2 Output: [4,5,1,2,3] class Solution: def rotateRight(self, …

嵌入式硬件实战提升篇(一)-泰山派RK3566制作多功能小手机

引言:主要针对于嵌入式全栈内容的知识点汇总并对于linux等相关驱动知识点进行串联,用大家参考学习,并用到了嘉立创提供的泰山派RK3566作为学习的主控。 实物演示如下所示: 目录 一、硬件设计 1.转接电路 2.背光电路 3.音频接…

wordpress functions文件的作用及详细说明

WordPress的functions.php文件是一个非常重要的主题文件,它允许开发者和用户向网站添加自定义代码片段,从而修改网站功能或添加新内容。以下是functions.php文件的主要作用和一些详细说明: 1. 自定义功能添加: functions.php文件…

什么是python爬虫?

今天就来给大家介绍一下什么是python爬虫。 Python爬虫是一种自动化程序,用于在互联网上浏览和提取信息。它通过模拟人类用户访问网页的行为,发送HTTP请求,获取网页内容,然后解析这些内容以提取所需数据 。以下是关于Python爬虫…

初级数据结构——栈

目录 前言一、栈的基本概念二、栈的实现方式三、栈的性能分析四、栈的应用场景五、栈的变体六、出栈入栈的动态图解七、代码模版八、总结结语 前言 数据结构栈(Stack)是一种线性的数据结构,它只允许在序列的一端(称为栈顶&#x…

第八章 利用CSS制作导航栏

8.1 水平顶部导航栏 8.1.1 简单水平导航栏的设计与实现 1. 响应式设计 介绍: 响应式设计是指网页能够根据不同设备屏幕尺寸和分辨率自适应调整布局和样式,以确保在手机、平板和桌面等设备上都能提供良好的用户体验。 CSS实现: media (ma…

NoSQL数据库与关系型数据库的主要区别

NoSQL数据库与关系型数据库在多个方面存在显著区别,以下是对这些主要区别的详细描述: 一、数据存储模型 关系型数据库:使用表格形式存储数据,每个表格由行和列组成,行表示记录,列表示字段。数据之间的关系…

PVE纵览-安装系统卡“Loading Driver”的快速解决方案

PVE纵览-安装系统卡“Loading Driver”的快速解决方案 文章目录 PVE纵览-安装系统卡“Loading Driver”的快速解决方案摘要通过引导参数解决PVE安装卡在“Loading Driver”问题官方解决方法 关键字: PVE、 显卡、 Loading、 Driver、 nomodeset 摘要 在虚拟机…