Mysql更新自增主键id遇到的问题
来源:脚本之家
时间:2022-12-30 12:48:28 235浏览 收藏
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《Mysql更新自增主键id遇到的问题》,涉及到Mysql自增主键id,有需要的可以收藏一下
本是一个自己知道的问题,还是差点踩坑(差点忘了,还好上线前整理上线点时想起来了),特此记录下来
为什么要更新自增id
我是因为历史业务上的坑,导致必须更新一批id,且为了避免冲突需要将id扩大多少倍进行更新,因为我这个表的数据数量不高,属于高读低写的情况,所以就简单的扩大了1000
问题
MySQL中如果我们把自增主键更新为更大的值(例如现在自增id最大值是1000,你更新id=49这个记录到id=1049),MySQL并不会把表的自增值修改为更新后的值,在某些情况下,如DDL,重启等之后,业务开始报错,这时如果不知道当前操作可能会误认为是当前业务操作的问题,实则是因为更新id埋下的坑(主键冲突)
如下图:
图1:更新前原始数据
执行更新语句
update test set id = 10 where id = 2;
图2:更新后的数据
执行新的插入语句
insert test (name) values ('dddd')
图3:插入的新数据
想必这时大家也都看出问题了,更新后可能刚开始没有问题,但当自增id追上你更新的最大值后,id冲突在所难免了。。。
如何解决
1.如果是个人测试库,不怎么重要,可以重启数据库
2.当然线上数据库是没法按照1这种方式搞了,除非你很任性(还需要dba陪着你任性),,,这时可以尝试指定id插入一条业务上无意义的数据,例如软删除的数据,(我的案列表没有软删除标识,大家可以意会下)
insert test (id,name) values (20,'eeee');
操作后如图:
在执行下面SQL语句,对照结果
insert test (name) values ('ffff');
此时自增id已从最大值开始自增了
找资料发现,这个BUG在2005年就被提出了,因为性能以及场景很少的没有被修复;这个问题在MySQL 8.0.11中表现正常。
今天关于《Mysql更新自增主键id遇到的问题》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
463 收藏
-
206 收藏
-
132 收藏
-
188 收藏
-
404 收藏
-
101 收藏
-
265 收藏
-
209 收藏
-
446 收藏
-
339 收藏
-
285 收藏
-
259 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 有魅力的砖头
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢大佬分享技术文章!
- 2023-06-21 08:56:18
-
- 可靠的路人
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢楼主分享技术文章!
- 2023-05-23 18:19:53
-
- 阳光的睫毛膏
- 这篇技术文章太及时了,太详细了,感谢大佬分享,码起来,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-03-26 21:46:15
-
- 畅快的猎豹
- 细节满满,已收藏,感谢作者大大的这篇文章,我会继续支持!
- 2023-02-26 22:22:51
-
- 寒冷的大碗
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢大佬分享技术文章!
- 2023-02-02 23:57:10
-
- 心灵美的苗条
- 好细啊,已加入收藏夹了,感谢大佬的这篇文章,我会继续支持!
- 2023-01-19 08:27:01
-
- 复杂的万宝路
- 这篇技术贴真及时,细节满满,受益颇多,收藏了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-16 17:35:15
-
- 朴实的小丸子
- 细节满满,码起来,感谢up主的这篇文章,我会继续支持!
- 2023-01-11 10:17:31
-
- 鳗鱼母鸡
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢博主分享技术文章!
- 2023-01-10 21:17:05
-
- 安静的泥猴桃
- 这篇技术文章出现的刚刚好,很详细,写的不错,码住,关注大佬了!希望大佬能多写数据库相关的文章。
- 2023-01-05 05:19:32
-
- 彩色的月光
- 这篇文章真及时,好细啊,写的不错,收藏了,关注up主了!希望up主能多写数据库相关的文章。
- 2023-01-05 03:26:02