SQL Server identity列的操作方法
[重要通告]如您遇疑難雜癥,本站支持知識(shí)付費(fèi)業(yè)務(wù),掃右邊二維碼加博主微信,可節(jié)省您寶貴時(shí)間哦!
SQL Server中,經(jīng)常會(huì)用到Identity標(biāo)識(shí)列,這種自增長(zhǎng)的字段操作起來(lái)的確是比較方便。但它有時(shí)還會(huì)帶來(lái)一些麻煩。
示例一:當(dāng)表中被刪除了某些數(shù)據(jù)的時(shí)候,自增長(zhǎng)列的編號(hào)就不再是一個(gè)連線的數(shù)列。這種時(shí)候我們可以用以下方案來(lái)解決。
SET IDENTITY_Insert [TABLE] [ON|OFF] |
允許將顯式值插入表的標(biāo)識(shí)列中,當(dāng)設(shè)置為ON時(shí),這時(shí)可能在Insert操作時(shí)手工指定插入到標(biāo)識(shí)列中的編號(hào),同時(shí)必須在操作完成后,將IDENTITY_Insert還原成OFF,否則下次插入的時(shí)候必須指定編號(hào),那不然就無(wú)法完成Insert操作。
示例二:當(dāng)表中的記錄被全部刪除,但此時(shí)標(biāo)識(shí)列的值越來(lái)越大的時(shí)候,如果不加以重置,它還會(huì)無(wú)休止的增長(zhǎng)。這個(gè)時(shí)候我們就要用到:
DBCC CHECKIDENT(TABLE, [RESEED|NORESEED], [1]) |
將把指定表的種子值強(qiáng)制重設(shè)為1。然而,你可能不想將種子重設(shè)為1,在這種情況下,你可以用你想用的種子值替代第三個(gè)參數(shù)。有時(shí)候你可能想知道當(dāng)前的種子,而不是想重設(shè)種子,這時(shí)你就要用到NORESEED,而不用再去顧忌第三個(gè)參數(shù)。
問(wèn)題未解決?付費(fèi)解決問(wèn)題加Q或微信 2589053300 (即Q號(hào)又微信號(hào))右上方掃一掃可加博主微信
所寫所說(shuō),是心之所感,思之所悟,行之所得;文當(dāng)無(wú)敷衍,落筆求簡(jiǎn)潔。 以所舍,求所獲;有所依,方所成!