淺談SQL Server identity列的操作方法

來源:互聯網
上載者:User

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

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

SET IDENTITY_INSERT [TABLE] [ON|OFF]

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

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

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

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

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.