主页>技术社区>IT 技术>数据库>SQL Server>SQL教程

IDENTITY列的检查指定表的当前标识值

eIT.com.cn 2022/11/26 23:24:39 阅读 55 次

打印


DBCC CHECKIDENT
  检查指定表的当前标识值,如有必要,还对标识值进行更正。
  
  语法
  DBCC CHECKIDENT
  ( 'table_name'
  [ , { ESEED
   { RESEED ][ , new_reseed_value ] }
  }
  ]
  )
  
  参数
  'table_name'
  是要对其当前标识值进行检查的表名。指定的表必须包含标识列。
  
  ESEED
  指定不应更正当前标识值。
  
  RESEED
  指定应该更正当前标识值。
  
  new_reseed_value
  是在标识列中重新赋值时要使用的值。
  
  注释
  如有必要,DBCC CHECKIDENT 会更正列的当前标识值。然而,假如标识列是使用 NOT FOR REPLICATION 子句(在 CREATE TABLE 或 ALTER TABLE 语句中)创建的,则不更正当前标识值。
  假如标识列上有主键或唯一键约束,无效标识信息可能会导致信息 2627。
  
  DBCC CHECKIDENT ('table_name', ESEED) 不重置当前标识值。DBCC CHECKIDENT 返回报表,它指明当前标识值和应有的标识值。
  DBCC CHECKIDENT ('table_name') 或
  DBCC CHECKIDENT ('table_name', RESEED) 假如表的当前标识值小于列中存储的最大标识值,则使用标识列中的最大值对其进行重置。
  DBCC CHECKIDENT ('table_name', RESEED, new_reseed_value) 当前值设置为 new_reseed_value。假如自创建表后没有将行插入该表,则在执行 DBCC CHECKIDENT 后插入的第一行将使用 new_reseed_value 作为标识。否则,下插入的行将使用 new_reseed_value + 1。假如 new_reseed_value 的值小于标识列中的最大值,以后引用该表时将产生 2627 号信息。
  
  当前标识值可以大于表中的最大值。在此情况下,DBCC CHECKIDENT 并不重置当前标识值。若要在当前标识值大于列中的最大值时对当前标识值进行重置,请使用两种中的任意一种:
  
  执行 DBCC CHECKIDENT ('table_name', ESEED) 以确定列中的当前最大值,然后使用 DBCC CHECKIDENT ('table_name', RESEED, new_reseed_value) 语句将该值指定为 new_reseed_value。
  
  将 new_reseed_value 置为很小值来执行 DBCC CHECKIDENT ('table_name', RESEED, new_reseed_value),然后运行 DBCC CHECKIDENT ('table_name', RESEED)。
  
  结果集
  不管是否指定任何选项(针对于包含标识列的表;下例使用 pubs jobs 表),DBCC CHECKIDENT 返回以下结果集(值可能会有变化):
  
  Checking identity @R_954_7@ion: current identity value '14', current column value '14'.
  DBCC execution completed. If DBCC printed error messages, contact your sy administrator.
  
  权限
  DBCC CHECKIDENT 权限认授予表所有者、sysadmin 固定服务器角色和 db_owner 固定角色的成员且不可转让。
  
  示例
  A. 如有必要,重置当前标识值
  下例在必要的情况下重置 jobs 表的当前标识值。
  
  USE pubs
  GO
  DBCC CHECKIDENT (jobs)
  GO
  
  B. 报告当前标识值
  下例报告 jobs 表中的当前标识值;假如该标识值不正确,并不对其进行更正。
  
  USE pubs
  GO
  DBCC CHECKIDENT (jobs, ESEED)
  GO
  
  C. 强制当前标识值为 30
  下例强制 jobs 表中的当前标识值为 30。
  
  USE pubs
  GO
  DBCC CHECKIDENT (jobs, RESEED, 30)
  GO

 

总结

以上是为你收集整理的全部内容。

如果觉得网站内容还不错,欢迎将推荐给好友。






相关内容


热门栏目


特别声明


最新资讯
热讯排行



合作媒体友情链接
生活常识小贴士 软件开发教程 智慧城市生活网 息县通生活服务[移动版] 息县商圈[移动版] 美食菜谱
健康养生 法律知识 科技频道 电影影讯 留学考研学习 星座生肖|解梦说梦




关于我们 | 联系我们 | 合作媒体 | 使用条款 | 隐私权声明 | 版权声明

      Copyright © 2023 eIT.com.cn. All Rights Reserved. 豫ICP备2022012332号