問題:數(shù)據(jù)庫自增的主鍵不連續(xù)轧铁,SQL的自增列挺好用,只是開發(fā)過程中一旦刪除數(shù)據(jù),標(biāo)識列就不連續(xù)了泣矛,寫起來,也很郁悶禾蚕。
Mysql
當(dāng)清空一個表的時候您朽,重新插入數(shù)據(jù),發(fā)現(xiàn)auto_increment屬性的字段計(jì)數(shù)不是從1開始的時候换淆,可以使用以下命令
- 手動修改
MySQL可以手動去修改主鍵哗总,但是主鍵一般不會修改。
還可以插入哪些被刪除的主鍵倍试。
- 刪庫
方法一
delete from test;
alter table `test` auto_increment=1
(好處讯屈,可以設(shè)置AUTO_INCREMENT 為任意值開始)
提示:如果表列和數(shù)據(jù)很多,速度會很慢县习,如90多萬條涮母,會在10分鐘以上。
方法二
truncate table test
(好處躁愿,簡單叛本,AUTO_INCREMENT 值重新開始計(jì)數(shù))
一般情況下我們使用第二個就可以了,記住以上情況都是徹底刪除所有記錄彤钟。
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