數(shù)據(jù)庫(kù)自增的主鍵不連續(xù)問(wèn)題

問(wèn)題:數(shù)據(jù)庫(kù)自增的主鍵不連續(xù),SQL的自增列挺好用,只是開(kāi)發(fā)過(guò)程中一旦刪除數(shù)據(jù),標(biāo)識(shí)列就不連續(xù)了,寫(xiě)起來(lái),也很郁悶。

Mysql

當(dāng)清空一個(gè)表的時(shí)候,重新插入數(shù)據(jù),發(fā)現(xiàn)auto_increment屬性的字段計(jì)數(shù)不是從1開(kāi)始的時(shí)候,可以使用以下命令

  1. 手動(dòng)修改

MySQL可以手動(dòng)去修改主鍵,但是主鍵一般不會(huì)修改。
還可以插入哪些被刪除的主鍵。

  1. 刪庫(kù)

方法一

delete from test;
alter table `test` auto_increment=1

(好處,可以設(shè)置AUTO_INCREMENT 為任意值開(kāi)始)
提示:如果表列和數(shù)據(jù)很多,速度會(huì)很慢,如90多萬(wàn)條,會(huì)在10分鐘以上。

方法二

truncate table test

(好處,簡(jiǎn)單,AUTO_INCREMENT 值重新開(kāi)始計(jì)數(shù))

一般情況下我們使用第二個(gè)就可以了,記住以上情況都是徹底刪除所有記錄。

SqlServer

–刪除原表數(shù)據(jù),并重置自增列

truncate table tablename  --truncate方式也可以重置自增字段

–重置表的自增字段,保留數(shù)據(jù)

DBCC CHECKIDENT (tablename,reseed,0) 

– 設(shè)置允許顯式插入自增列

SET IDENTITY_INSERT tablename  ON

– 當(dāng)然插入完畢記得要設(shè)置不允許顯式插入自增列

SET IDENTITY_INSERT tablename  Off
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容