程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 淺談SQL Server identity列的操作方法

淺談SQL Server identity列的操作方法

編輯:關於SqlServer

SQL Server中,經常會用到Identity標識列,這種自增長的字段操作起來的確是比較方便。但它有時還會帶來一些麻煩。

示例一:當表中被刪除了某些數據的時候,自增長列的編號就不再是一個連線的數列。這種時候我們可以用以下方案來解決。

SET IDENTITY_INSERT [TABLE] [ON|OFF]

允許將顯式值插入表的標識列中,當設置為ON時,這時可能在INSERT操作時手工指定插入到標識列中的編號,同時必須在操作完成後,將IDENTITY_INSERT還原成OFF,否則下次插入的時候必須指定編號,那不然就無法完成INSERT操作。

示例二:當表中的記錄被全部刪除,但此時標識列的值越來越大的時候,如果不加以重置,它還會無休止的增長。這個時候我們就要用到:

DBCC CHECKIDENT(TABLE, [RESEED|NORESEED], [1])

將把指定表的種子值強制重設為1。然而,你可能不想將種子重設為1,在這種情況下,你可以用你想用的種子值替代第三個參數。有時候你可能想知道當前的種子,而不是想重設種子,這時你就要用到NORESEED,而不用再去顧忌第三個參數。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved