当前位置:Gxlcms > 数据库问题 > sqlserver 重置自增列种子值最大值

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

时间:2021-07-01 10:21:17 帮助过:5人阅读

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的值。     参考:  https://msdn.microsoft.com/en-us/library/ms176057.aspx              https://msdn.microsoft.com/en-us/library/ms175098.aspx 来源:https://www.cnblogs.com/Rayblog/p/6213565.html

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

标签:sdn   arp   设置   查看   注意   出现   问题:   name   eric   

人气教程排行