重置sqlserver自增长列的种子

转自:http://hi.baidu.com/zbphot/item/41c55982c2d02dd05e0ec184

如果表中的数据不要了,用下面的语句:  truncate table表

如果表中的语句还要,用下面的语句:  DBCC CHECKIDENT (表名, RESEED, 1)

DBCC CHECKIDENT ('table_name', NORESEED) 不重置当前标识值。

DBCC CHECKIDENT 返回一个报表,它指明当前标识值和应有的标识值。

DBCC CHECKIDENT ('table_name')或DBCC CHECKIDENT ('table_name', RESEED)  如果表的当前标识值小于列中存储的最大标识值,则使用标识列中的最大值对其进行重置。

DBCC CHECKIDENT ('table_name', RESEED, new_reseed_value)  当前值设置为 new_reseed_value。 如果自创建表后没有将行插入该表,则在执行  DBCC CHECKIDENT 后插入的第一行将使用 new_reseed_value 作为标识。 否则,下一个插入的行将使用 new_reseed_value + 1。 如果 new_reseed_value 的值小于标识列中的最大值, 以后引用该表时将产生 2627 号错误信息。

如果表中的语句还要,用下面的语句:

DBCC CHECKIDENT (表名, RESEED, 1)

DBCC CHECKIDENT ('table_name', NORESEED) 不重置当前标识值。

DBCC CHECKIDENT 返回一个报表,它指明当前标识值和应有的标识值。

DBCC CHECKIDENT ('table_name')或DBCC CHECKIDENT ('table_name', RESEED)  如果表的当前标识值小于列中存储的最大标识值,则使用标识列中的最大值对其进行重置。  DBCC CHECKIDENT ('table_name', RESEED, new_reseed_value)  当前值设置为 new_reseed_value,一般new_reseed_value是当前最大的ID值。 如果自创建表后没有将行插入该表,则在执行  DBCC CHECKIDENT 后插入的第一行将使用 new_reseed_value 作为标识。 否则,下一个插入的行将使用 new_reseed_value + 1。 如果 new_reseed_value 的值小于标识列中的最大值, 以后引用该表时将产生 主键冲突的错误

05-11 17:31