MySQL8自增主键变化[亲测有效]

MySQL8自增主键变化[亲测有效]MySQL8自增主键变化 醉后不知天在水,满船清梦压星河。 一、简述 MySQL版本从5直接大跃进到8,相信MySQL8一定会有很多令人意想不到的改进,如果不想只会CRUD可以看看。 比如系统表引擎的

MySQL8自增主键变化

MySQL8自增主键变化

 

     醉后不知天在水,满船清梦压星河。

 

一、简述

MySQL版本从5直接大跃进到8,相信MySQL8一定会有很多令人意想不到的改进,如果不想只会CRUD可以看看。

比如系统表引擎的变化-全部换成事务型的InnoDB。

MySQL5.7系统部引擎

MySQL8自增主键变化[亲测有效]

MySQL8系统引擎 

MySQL8自增主键变化[亲测有效]

上图可以看到,MySQL5.7的系统表引擎有MEMORY、InnnoDB和MyISAM三种,但MySQL8的系统表引擎都换成了InnoDB。MySQL8新特性还有很多,接下来进入正题康康它的自增主键。

二、MySQL自增主键

为什么MySQL8新特性会修改自增主键属性?

在MySQL8.0之前,自增主键 AUTO_INCREMENT 的值如果大于max(primary key) +1,那么在MySQL重启后,则会重置 AUTO_INCREMENT = max(primary key)+1 的值,这种现象在某些情况下会导致业务主键冲突或者其他难以发现的一些问题。

MySQL官网解释自增ID冲突问题
MySQL8自增主键变化[亲测有效]

因为在MySQL5.7中,对于自增主键的分配规则是由InnoDB数据字典内部一个计数器来决定的,而该计数器维护在了内存中,并不会持久化到磁盘中,此时硬盘中并无数据,当数据库重启的时候,该计数器会被初始化为: auto_increment = max(primary key)+1。

如何解决自增主键冲突问题?

这个问题一直到MySQL8.0才解决。
8.0版本将会对 AUTO_INCREMENT 值进行持久化,所以即使MySQL重启后该值也不会改变。
即其将自增主键的计数器持久化到了重做日志中,每次计数器发生改变都会将其写入到重做日志中,如果这个时候数据库重启了,那么InnoDB数据字典会根据重做日志中的信息来初始化计数器的内存值,就可以恢复到了上次关闭数据库前的状态,通过自增ID持久化来避免8.0之前可能会出现的问题。

三、自增主键测试

分别在MySQL5和MySQL8上进行自增主键测试。

1、MySQL5.7自增主键

在MySQL5.7中的,这里我们先创建一个数据表,这个数据表中设置一个自增列。

CREATE TABLE t_test_auto_increment_tjt(
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT "主键ID",
  `test_key` varchar(50) NOT NULL COMMENT "名称",
  `test_value` varchar(50) DEFAULT NULL COMMENT "",
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT="测试主键自增表";

然后向自增主键表中添加了4条记录,表中的四条添加的记录的id字段值就分别为: 1、2、3、4。

INSERT INTO t_test_auto_increment_tjt(id, test_key, test_value) VALUES
("0","吞噬星空","停更"),
("0","水斗大陆","可以停播了"),
("0","武神主宰","装B还得看尘少"),
("0","完美世界","yyds")

插入数据的SQL添加的是0,其实就是默认赋值,表 t_test_auto_increment_tjt 中的自增列是不可以添加0或者null的,那么这个时候表中的四条添加的记录的id字段值就分别为: 11、2、3、4。

MySQL8自增主键变化[亲测有效]

接下来,将表中的id为4的字段删除。

DELETE FROM t_test_auto_increment_tjt WHERE id = 4

然后,继续在表中添加一条记录,执行之后我们可以发现,此时自增主键的ID结果是5。

INSERT INTO t_test_auto_increment_tjt(id, test_key, test_value) VALUES ("0","完美世界","yyds-YYDS")

MySQL8自增主键变化[亲测有效]

因为我们前面已经将表中id为4的记录删除了,这个时候下一次自增的时候即使表中没有id为4的字段了,但是这个时候我们也不会添加4,而是添加5。其实这个时候就是自增主键的值auto_increment 大于了max(primary key)+1。
再接下来,将表中的id为5的记录删除。

DELETE FROM t_test_auto_increment_tjt WHERE id = 5

最后,重启MySQL数据库,再向表中添加一条记录。

INSERT INTO t_test_auto_increment_tjt(id, test_key, test_value) VALUES ("0","完美世界","yyds-YYDS-restart")

MySQL8自增主键变化[亲测有效]

上图可以看到,重启后 重启后 重启后 执行的结果中添加的记录的id值为 : 4, 按之前的操作来看4和5已经被删除了,那么添加的就应该是6,为什么是4呢?

因为在MySQL5.7中,自增主键的分配规则是由InnoDB数据字典内部一个计数器来决定的,而该计数器维护在了内存中,并不会持久化到磁盘中,此时硬盘中并无数据,当数据库重启之后该计数器会被初始化为: auto_increment = max(primary key)+1,所以记录的id=4,而不是6。

2、MySQL8自增主键

在MySQL8中,按照上述MySQL5.7的操作步骤测试自增主键问题。

首先创建自增主键表、插入数据。

MySQL8自增主键变化[亲测有效]

然后,删除数据、插入数据。

MySQL8自增主键变化[亲测有效]

最后,重启 重启 重启 重启后插入数据。

MySQL8自增主键变化[亲测有效]

一定要彻底关闭MySQL服务,然后重新启动。

MySQL8自增主键变化[亲测有效]

重启后插入数据,测试自增主键ID的值?

MySQL8自增主键变化[亲测有效]

 

 

 

 

醉后不知天在水

        满船清梦压星河

 

 

 

 

原文地址:https://www.cnblogs.com/taojietaoge/archive/2022/04/17/16143104.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5361.html

(0)
上一篇 2023-05-12
下一篇 2023-05-12

相关推荐

  • 使用Python创建新的目录

    使用Python创建新的目录在日常工作和生活中,创建新的目录是一件非常常见的事情,经常需要手动新建一些文件夹,但是当需要新建的目录较多时,手动创建将变得非常耗时,效率也很低。因此,我们需要寻找一种简单高效的方法来创建新的目录,而使用Python可以帮助我们快速地实现这一目标。

    2024-03-04
    81
  • 使用bs4.select解析网页中的标题元素

    使用bs4.select解析网页中的标题元素在网络爬取和数据分析中,常常需要使用Python对网页进行解析,获取网页中所需的数据和信息。其中,使用bs4库中的select方法来解析网页中的标题元素h1/h1,生成一个纯净、简洁的标题是一个很常见的需求。本文将从不同角度介绍使用bs4.select解析网页中的标题元素的技巧与方法。

    2024-07-19
    40
  • Python 制表符的使用

    Python 制表符的使用 Python 是一种高级编程语言,它的设计目的是为了让程序员更容易编写、阅读和维护代码。Python 可以使用制表符来表示代码的缩进,从而帮助程序员更好地组织代码。制表符在 Python 中是非常重要的,因为它们不仅是程序的可读性,而且还可以对程序的语义有所帮助。

    2024-08-09
    31
  • 高可用 | 关于 Xenon 高可用的一些思考「终于解决」

    高可用 | 关于 Xenon 高可用的一些思考「终于解决」原创:知数堂 上一篇文章,我们详细介绍了 Xenon 实现 MySQL 高可用架构的常用操作。本篇将对关于 Xenon 高可用的一些思考及高频问题进行解答。 问题 1:宕机时 binlog 有 gap

    2023-04-22
    141
  • Python 列表的强大应用:实现高效数据存储和处理

    Python 列表的强大应用:实现高效数据存储和处理在Python编程中,列表(List)是一种重要的数据结构,它可以用来存储一个有序的元素序列。List的强大应用包括但不限于:

    2024-02-18
    84
  • oracle invalid number_oracle31626

    oracle invalid number_oracle31626出现ora-31655错误的情况 原因:是因为不是同一个schema,导致的问题产生 解决方案: 在导入语句最后添加上remap_schema=old:new 着old是原schema,也就是导出的用

    2023-03-01
    154
  • Python中的含义

    Python中的含义Python是一种高级、互动式、面向对象的编程语言,具有简洁易读的语法和强大的内置函数。它由Guido van Rossum于1989年创造,主要是为了提高程序员的工作效率。

    2024-06-06
    63
  • 收购安全公司Shape对F5安全解决方案有什么重大意义?「建议收藏」

    收购安全公司Shape对F5安全解决方案有什么重大意义?「建议收藏」     众所周知,2020年2月6日,全球知名应用交付商F5 Networks(NASDAQ:FFIV)以大约10亿美元的现金总价收购私有公司Shape的所有已发行股票和流通股,以进行战略调整。但…

    2023-02-05
    140

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注