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

编程之家收集整理的这篇文章主要介绍了IDENTITY列的检查指定表的当前标识值编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

DBCC CHECKIDENT
  检查指定表的当前标识值,如有必要,还对标识值进行更正。
  
  语法
  DBCC CHECKIDENT
  ( 'table_name'
  [ , { norESEED
   { RESEED ][ , new_reseed_value ] }
  }
  ]
  )
  
  参数
  'table_name'
  是要对其当前标识值进行检查的表名。指定的表必须包含标识列。
  
  norESEED
  指定不应更正当前标识值。
  
  RESEED
  指定应该更正当前标识值。
  
  new_reseed_value
  是在标识列中重新赋值时要使用的值。
  
  注释
  如有必要,DBCC CHECKIDENT 会更正列的当前标识值。然而,假如标识列是使用 NOT FOR REPLICATION 子句(在 CREATE TABLE 或 ALTER TABLE 语句中)创建的,则不更正当前标识值。
  假如标识列上有主键或唯一键约束,无效标识信息可能会导致错误信息 2627。
  
  DBCC CHECKIDENT ('table_name', norESEED) 不重置当前标识值。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', norESEED) 以确定列中的当前最大值,然后使用 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 information: current identity value '14', current column value '14'.
  DBCC execution completed. If DBCC printed error messages, contact your system administrator.
  
  权限
  DBCC CHECKIDENT 权限认授予表所有者、sysadmin 固定服务器角色和 db_owner 固定数据库角色的成员且不可转让。
  
  示例
  A. 如有必要,重置当前标识值
  下例在必要的情况下重置 jobs 表的当前标识值。
  
  USE pubs
  GO
  DBCC CHECKIDENT (jobs)
  GO
  
  B. 报告当前标识值
  下例报告 jobs 表中的当前标识值;假如该标识值不正确,并不对其进行更正。
  
  USE pubs
  GO
  DBCC CHECKIDENT (jobs, norESEED)
  GO
  
  C. 强制当前标识值为 30
  下例强制 jobs 表中的当前标识值为 30。
  
  USE pubs
  GO
  DBCC CHECKIDENT (jobs, RESEED, 30)
  GO

 

小编说

以上是编程之家为你收集整理的IDENTITY列的检查指定表的当前标识值全部内容。

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


本篇内容主要讲解“sqlalchemy的常用数据类型怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sqlalche...
1. mssql权限sa权限:数据库操作,文件管理,命令执行,注册表读取等system。是mssql的最高权限db权限:文件管理,数据库操作等 users-administratorspublic权限:数据库操作 guest-users2、sql server注入执行命令查
本页概要如果您使用的是 SQL Server 2005备份和还原Sp_detach_db 和 Sp_attach_db 存储过程关于排序规则的说明导入和导出数据(在 SQL Server 数据库之间复
DBCC CHECKIDENT 检查指定表的当前标识值,如有必要,还对标识值进行更正。 语法 DBCC CHECKIDENT ( 'table_name' [ , { NORESEED
这里对 SQL Server 字符串函数进行分门别类地列出,便于查阅和记忆,相信大家都在其它方面有高深的编程基础,从字面上来说大家都知道这些函数的意义,就不对这些函数作过多的解释了,主要谈些经验,具体
查询及删除重复记录的方法 1、查找表(people)中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select*frompeoplewherepeopleIdin(selectpe
微软发SQL Server 2008第二个CTP预览版from: http://news.csdn.net/n/20070807/107158.html8月7日消息,微软公司本周发布了SQL Serv
症状当您将数据库备份恢复到另一台服务器时,可能会遇到孤立用户的问题。SQL Server 联机丛书中的孤立用户疑难解答主题中没有讲述解决此问题的具体步骤。本文介绍了如何解决孤立用户问题。更多信息虽然术
当登录SQL Server 2005时可能碰到错误: 'No Process is on the Other End of the Pipe'。解决方法:(1)Open up SQL
概要本文描述如何映射标准登录和集成登录来解决在运行 SQL Server 的服务器之间移动数据库时的权限问题。更多信息当您将数据库从一个运行 SQL Server 的服务器移到另一个运行 SQL Se