sqlserver 重置自增列种子值 违反了 PRIMARY KEY 约束的处理
SQLServer 处理 Key 约束 重置 PRIMARY 种子 增列
2023-09-11 14:19:35 时间
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的全文目录跟全文索引的区别
- asp.net, c# 查询大于某一时间的数据, sql语句 用于SQLServer(mssql)
- SqlServer用select查询遇到Null值字段的处理替换方法(实例)
- 在SqlServer 中解析JSON数据
- sqlserver的触发器练习实例
- 浅析SqlServer简单参数化模式下对sql语句自动参数化处理以及执行计划重用
- sqlserver中drop、truncate和delete语句的用法
- sqlserver快速查找所有存储过程中是否包含某字符
- sqlserver 时间格式转换汇总:日、周、月、年、小时、分钟、秒 等。
- SqlServer-- NULL空值处理
- How to select a OptionSet on ms sqlserver database for Microsoft Dynamics CRM
- SQLServer中创建主键的方法
- SQLSERVER排查CPU占用高的情况
- [转]SqlServer中Sql查看存储过程
- Sqlserver 分页