SQLServer数据库DBCC CHECKIDENT命令介绍

在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://www.cnblogs.com/Rayblog/p/6213565.html

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值