sqlserver 重置自增列种子值最大值

Posted fogwu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlserver 重置自增列种子值最大值相关的知识,希望对你有一定的参考价值。

DBCC CHECKIDENT(sysmenu, RESEED, 184)
设置sysmenu表的自增初始值为184

命令介绍:

在SQLServer输入数据时,碰到有主键ID需要维护时,可使用IDENT_CURRENT和CHECKIDENT命令来维护。
 
IDENT_CURRENT命令返回指定表或视图生成的最后一个标识值。用法如下:
 
     IDENT_CURRENT(\'table_name\')
 
返回类型numeric(38,0).
 
 
DBCC  CHECKIDENT命令用于检查或指定当前表/视图的标识值。用法如下:
 
DBCC CHECKIDENT
(
     table_name
          [, {NORESEED | {RESEED [, new_reseed_value] } } ]
)
[WITH NO_INFOSGS]
 
 
一般我们的用法如下:
1) 查看且如有必要更正当前标识值:
     DBCC CHECKIDENT(\'table_name\')
 
2) 查看当前标识值,即使有错也不视图更正:
     DBCC CHECKIDENT(\'table_name\', NORESEED)
 
3) 指定新的标识值:
     DBCC CHECKIDENT(\'table_name\', RESEED, new_reseed_value)
 
WITH NO_INFOSGS是关闭消息提示。
 
--------------------------------------------------
 
需要注意的问题:
当设置的new_reseed_value小于表中主键ID的值时,后续再插入过程中会出现以下错误:
 a) 当主键或唯一约束存在时,会报2627错误,因为当前的主键值已在数据表中,产生冲突;
 b) 当主键或唯一约束不存在时,会报重复主键错误。
 
解决方法:
 先使用select max(id) from table_name, 查询出表中最大的ID,然后重新设置一个比其打的new_reseed_value;
 如果表中数据已经删除,可以使用DBCC CHECKIDENT(\'table_name\', NORESEED, 1)置为1,然后用DBCC CHECKIDEN(\'table_name\')来修正。
 
另外,在SQL中,如果要插入ID,一般我们可以用select IDENT_CURRENT(\'table_name\')+1 来插入比当前序列值多1的值。
 
 

以上是关于sqlserver 重置自增列种子值最大值的主要内容,如果未能解决你的问题,请参考以下文章

怎么重置mysql的自增列AUTO

sql server 2000 中怎么去掉 和 还原 自增字段

如何修改MySql自增列的值

怎么重置mysql的自增列AUTO_INCREMENT初时值

sql 自增列删除

转:SqlServer2012自增列值突然增大1000的原因及解决方法