Mysql更新自增主鍵id遇到的問(wèn)題
本是一個(gè)自己知道的問(wèn)題,還是差點(diǎn)踩坑(差點(diǎn)忘了,還好上線前整理上線點(diǎn)時(shí)想起來(lái)了),特此記錄下來(lái)
為什么要更新自增id
我是因?yàn)闅v史業(yè)務(wù)上的坑,導(dǎo)致必須更新一批id,且為了避免沖突需要將id擴(kuò)大多少倍進(jìn)行更新,因?yàn)槲疫@個(gè)表的數(shù)據(jù)數(shù)量不高,屬于高讀低寫的情況,所以就簡(jiǎn)單的擴(kuò)大了1000
問(wèn)題
MySQL中如果我們把自增主鍵更新為更大的值(例如現(xiàn)在自增id最大值是1000,你更新id=49這個(gè)記錄到id=1049),MySQL并不會(huì)把表的自增值修改為更新后的值,在某些情況下,如DDL,重啟等之后,業(yè)務(wù)開始報(bào)錯(cuò),這時(shí)如果不知道當(dāng)前操作可能會(huì)誤認(rèn)為是當(dāng)前業(yè)務(wù)操作的問(wèn)題,實(shí)則是因?yàn)楦耰d埋下的坑(主鍵沖突)
如下圖:
圖1:更新前原始數(shù)據(jù)
執(zhí)行更新語(yǔ)句
update test set id = 10 where id = 2;
圖2:更新后的數(shù)據(jù)
執(zhí)行新的插入語(yǔ)句
insert test (name) values ('dddd')
圖3:插入的新數(shù)據(jù)
想必這時(shí)大家也都看出問(wèn)題了,更新后可能剛開始沒有問(wèn)題,但當(dāng)自增id追上你更新的最大值后,id沖突在所難免了。。。
如何解決
1.如果是個(gè)人測(cè)試庫(kù),不怎么重要,可以重啟數(shù)據(jù)庫(kù)
2.當(dāng)然線上數(shù)據(jù)庫(kù)是沒法按照1這種方式搞了,除非你很任性(還需要dba陪著你任性),,,這時(shí)可以嘗試指定id插入一條業(yè)務(wù)上無(wú)意義的數(shù)據(jù),例如軟刪除的數(shù)據(jù),(我的案列表沒有軟刪除標(biāo)識(shí),大家可以意會(huì)下)
insert test (id,name) values (20,'eeee');
操作后如圖:
在執(zhí)行下面SQL語(yǔ)句,對(duì)照結(jié)果
insert test (name) values ('ffff');
此時(shí)自增id已從最大值開始自增了
找資料發(fā)現(xiàn),這個(gè)BUG在2005年就被提出了,因?yàn)樾阅芤约皥?chǎng)景很少的沒有被修復(fù);這個(gè)問(wèn)題在MySQL 8.0.11中表現(xiàn)正常。
到此這篇關(guān)于Mysql更新自增主鍵id遇到的問(wèn)題的文章就介紹到這了,更多相關(guān)Mysql更新自增主鍵id內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
幾個(gè)常見的MySQL的可優(yōu)化點(diǎn)歸納總結(jié)
這篇文章主要介紹了幾個(gè)常見的MySQL的可優(yōu)化點(diǎn)歸納總結(jié),包括在編程時(shí)處理索引、分頁(yè)以及數(shù)據(jù)類型時(shí)可用到的地方,需要的朋友可以參考下2015-05-05超簡(jiǎn)單的qps統(tǒng)計(jì)方法(推薦)
下面小編就為大家?guī)?lái)一篇超簡(jiǎn)單的qps統(tǒng)計(jì)方法(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03mysql 月份查詢?cè)撛掠懈犊畹臄?shù)據(jù)
mysql選擇月份查詢?cè)撛掠懈犊畹臄?shù)據(jù)(間隔x月并提前5天付款)2010-04-04MYSQL造數(shù)據(jù)占用臨時(shí)表空間的解決方法
在MySQL中,臨時(shí)表空間并不是一個(gè)可以直接刪除的文件或目錄,因?yàn)榕R時(shí)表空間通常是由MySQL服務(wù)器在運(yùn)行時(shí)根據(jù)需要自動(dòng)創(chuàng)建和管理的,這篇文章主要介紹了MYSQL造數(shù)據(jù)占用臨時(shí)表空間,需要的朋友可以參考下2024-05-05