有关identity的小技巧
生活随笔
收集整理的這篇文章主要介紹了
有关identity的小技巧
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
SQL Server中,經(jīng)常會用到Identity標(biāo)識列,這種自增長的字段操作起來的確是比較方便。但它有時還會帶來一些麻煩。?
示例一 :當(dāng)表中被刪除了某些數(shù)據(jù)的時候,自增長列的編號就不再是一個連線的數(shù)列。這種時候我們可以用以下方案來解決。?
SET IDENTITY_INSERT [TABLE] [ON|OFF]
允許將顯式值插入表的標(biāo)識列中,當(dāng)設(shè)置為ON時,這時可能在INSERT操作時手工指定插入到標(biāo)識列中的編號,同時必須在操作完成后,將IDENTITY_INSERT還原成OFF,否則下次插入的時候必須指定編號,那不然就無法完成INSERT操作。?
示例二:當(dāng)表中的記錄被全部刪除,但此時標(biāo)識列的值越來越大的時候,如果不加以重置,它還會無休止的增長。這個時候我們就要用到:?
DBCC CHECKIDENT(TABLE, [RESEED|NORESEED], [1])
將把指定表的種子值強制重設(shè)為1。然而,你可能不想將種子重設(shè)為1,在這種情況下,你可以用你想用的種子值替代第三個參數(shù)。有時候你可能想知道當(dāng)前的種子,而不是想重設(shè)種子,這時你就要用到NORESEED,而不用再去顧忌第三個參數(shù)。
示例一 :當(dāng)表中被刪除了某些數(shù)據(jù)的時候,自增長列的編號就不再是一個連線的數(shù)列。這種時候我們可以用以下方案來解決。?
SET IDENTITY_INSERT [TABLE] [ON|OFF]
允許將顯式值插入表的標(biāo)識列中,當(dāng)設(shè)置為ON時,這時可能在INSERT操作時手工指定插入到標(biāo)識列中的編號,同時必須在操作完成后,將IDENTITY_INSERT還原成OFF,否則下次插入的時候必須指定編號,那不然就無法完成INSERT操作。?
示例二:當(dāng)表中的記錄被全部刪除,但此時標(biāo)識列的值越來越大的時候,如果不加以重置,它還會無休止的增長。這個時候我們就要用到:?
DBCC CHECKIDENT(TABLE, [RESEED|NORESEED], [1])
將把指定表的種子值強制重設(shè)為1。然而,你可能不想將種子重設(shè)為1,在這種情況下,你可以用你想用的種子值替代第三個參數(shù)。有時候你可能想知道當(dāng)前的種子,而不是想重設(shè)種子,這時你就要用到NORESEED,而不用再去顧忌第三個參數(shù)。
總結(jié)
以上是生活随笔為你收集整理的有关identity的小技巧的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 更改Web.config中对上传文件大小
- 下一篇: 一个程序员的感慨的《虚拟光驱》