• 13793 阅读
  • 1 回复

SQL Server 如何重新恢复自动编号列的序号


在sql server中经常有这样的问题:
一个表采用了自动编号的列之后,由于测试了好多数据,自动编号已累计了上万个。现在正是要用这个表了,测试数据已经删了,遗留下来的问题 就是 在录入新的数据,编号只会继续增加,已使用过的但已删除的编号就不能用了, 谁知道如何解决此问题?


truncate命令不但会清除所有的数据,还会将IDENTITY的SEED的值恢复到原是值。


而DBCC CHECKIDENT则更加方便一些,可以在不删除数据的情况下指定SEED的值。
1. truncate table tablename
2. DBCC CHECKIDENT (tablename,reseed,1)
语句说明:DBCC   CHECKIDENT   (表名,   RESEED,   起始值)

DBCC CHECKIDENT 只是将自动编排的所引号的指向移到了所指定的位置,实际的编号并没有发生改变,但有新纪录插入时自动编号就会按照制定的记录号开始并累加,如果遇到累加的记录号已经存在,那么就跳过这些号。
DBCC   CHECKIDENT   (表名, RESEED, 起始值)

【起始值】取值应该注意:

新表(刚建好还没有插入过数据):自动增量会从0开始
空表(曾经插入过数据,但是现在是空的):自动增量会从1开始