zoukankan      html  css  js  c++  java
  • 关于SQLServer数据库DBCC CHECKIDENT命令

    在SQLServer输入数据时,碰到有主键ID需要维护时,可使用IDENT_CURRENT和CHECKIDENT命令来维护。
     
    一般我们的用法如下:
    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的值。
     
     
    IDENT_CURRENT命令返回指定表或视图生成的最后一个标识值。用法如下:
     
         IDENT_CURRENT('table_name')
    返回类型numeric(38,0).
     
    DBCC  CHECKIDENT命令用于检查或指定当前表/视图的标识值。用法如下:
     
    DBCC CHECKIDENT
    (
         table_name
              [, {NORESEED | {RESEED [, new_reseed_value] } } ]
    )
    [WITH NO_INFOSGS]
  • 相关阅读:
    (转载)openwrt nginx
    *** 竞赛中的各种低级错误,及编程常见错误小结 ***
    信息学奥赛辅导经验谈 & 问题教学法中的学生思维能力培养
    数学&数论的一些题
    信息学竞赛中的一些经典思维 (题)
    从权值线段树到主席树
    浅谈莫队算法
    CSP-S 2019提高组训练 服务器需求
    NOIP2019 PJ 对称二叉树
    NOIP2017 PJ 跳房子 —— 单调队列优化DP
  • 原文地址:https://www.cnblogs.com/wissly/p/13574399.html
Copyright © 2011-2022 走看看