服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - Mysql更新自增主键id遇到的问题

Mysql更新自增主键id遇到的问题

2022-01-12 18:19code1Boy Mysql

本文主要介绍了Mysql更新自增主键id遇到的问题,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本是一个自己知道的问题,还是差点踩坑(差点忘了,还好上线前整理上线点时想起来了),特此记录下来

为什么要更新自增id

我是因为历史业务上的坑,导致必须更新一批id,且为了避免冲突需要将id扩大多少倍进行更新,因为我这个表的数据数量不高,属于高读低写的情况,所以就简单的扩大了1000

问题

mysql中如果我们把自增主键更新为更大的值(例如现在自增id最大值是1000,你更新id=49这个记录到id=1049),mysql并不会把表的自增值修改为更新后的值,在某些情况下,如ddl,重启等之后,业务开始报错,这时如果不知道当前操作可能会误认为是当前业务操作的问题,实则是因为更新id埋下的坑(主键冲突)
如下图:

图1:更新前原始数据

Mysql更新自增主键id遇到的问题

执行更新语句

?
1
update test set id = 10 where id = 2;

图2:更新后的数据

Mysql更新自增主键id遇到的问题

执行新的插入语句

?
1
insert test (name) values ('dddd')

图3:插入的新数据

Mysql更新自增主键id遇到的问题

想必这时大家也都看出问题了,更新后可能刚开始没有问题,但当自增id追上你更新的最大值后,id冲突在所难免了。。。

如何解决

1.如果是个人测试库,不怎么重要,可以重启数据库
2.当然线上数据库是没法按照1这种方式搞了,除非你很任性(还需要dba陪着你任性),,,这时可以尝试指定id插入一条业务上无意义的数据,例如软删除的数据,(我的案列表没有软删除标识,大家可以意会下)

?
1
insert test (id,name) values (20,'eeee');

操作后如图:

Mysql更新自增主键id遇到的问题

在执行下面sql语句,对照结果

?
1
insert test (name) values ('ffff');

Mysql更新自增主键id遇到的问题

此时自增id已从最大值开始自增了

找资料发现,这个bug在2005年就被提出了,因为性能以及场景很少的没有被修复;这个问题在mysql 8.0.11中表现正常。

到此这篇关于mysql更新自增主键id遇到的问题的文章就介绍到这了,更多相关mysql更新自增主键id内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/code1Boy/article/details/121589152

延伸 · 阅读

精彩推荐
  • Mysqlmysql 8.0.20 winx64.zip压缩版安装配置方法图文教程

    mysql 8.0.20 winx64.zip压缩版安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql 8.0.20 winx64.zip压缩版安装配置方法图文教程,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们...

    Java潘老师10362021-01-16
  • Mysql基于SQL中的数据查询语句汇总

    基于SQL中的数据查询语句汇总

    以下是对SQL中的数据查询语句进行了汇总介绍,需要的朋友可以过来参考下 ...

    MYSQL教程网2972020-01-07
  • MysqlWin7 安装 Mysql 5.6的教程图解

    Win7 安装 Mysql 5.6的教程图解

    这篇文章主要介绍了Win7 安装 Mysql 5.6的教程,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    蒜丶4552020-12-07
  • Mysqlmysql 5.7.17 winx64安装配置图文教程

    mysql 5.7.17 winx64安装配置图文教程

    这篇文章主要为大家分享了mysql 5.7.17 winx64安装配置方法图文教程,感兴趣的朋友可以参考一下...

    Rebirth_Love2622020-07-11
  • MysqlMysql Online DDL的使用详解

    Mysql Online DDL的使用详解

    在日常DBA运维过程中,对表结构进行变更算是个普遍的需求了。如果操作的对象是个热表、大表,难免心里一怵,这些DDL操作是否可以直接执行,哪些会影...

    xmebcc5722021-07-18
  • Mysql阿里云centos7中安装MySQL8.0.13的方法步骤

    阿里云centos7中安装MySQL8.0.13的方法步骤

    这篇文章主要介绍了阿里云centos7中安装MySQL8.0.13的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    LovelyCat8462021-01-22
  • MysqlMySQL update 语句的正确用法

    MySQL update 语句的正确用法

    今天我们主要向大家讲述的是MySQL update 语句的实际用法,以及在实际操作中哪些相关的操作步骤是值得我们大家注意的。...

    博客园3772021-05-20
  • Mysql图文介绍mysql中:=和=的区别

    图文介绍mysql中:=和=的区别

    这篇文章主要给大家介绍了关于mysql中:=和=区别的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的...

    干净的句号3482020-11-28