問(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í)候,可以使用以下命令
- 手動(dòng)修改
MySQL可以手動(dòng)去修改主鍵,但是主鍵一般不會(huì)修改。
還可以插入哪些被刪除的主鍵。
- 刪庫(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