SQL Server 如何重新恢复自动编号列的序号
-
一片云
2016-02-14 21:22
在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开始