SQL Server identity列,美中不足之處
以下的文章主要向大家講述的是SQL Server identity列,我們大家都知道SQL Server Identity標(biāo)識(shí)列,這種自增長(zhǎng)的字段在實(shí)際操作中,用起來十分的簡(jiǎn)便,但是美中不足的是它有時(shí)還會(huì)帶來一些麻煩。
示例一 :當(dāng)表中被刪除了某些數(shù)據(jù)的時(shí)候,自增長(zhǎng)列的編號(hào)就不再是一個(gè)連線的數(shù)列。這種時(shí)候我們可以用以下方案來解決。
- 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),那不然就無法完成INSERT操作。
示例二:當(dāng)表中的記錄被全部刪除,但此時(shí)標(biāo)識(shí)列的值越來越大的時(shí)候,如果不加以重置,它還會(huì)無休止的增長(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ù)。 以上的相關(guān)內(nèi)容就是對(duì)SQL Server identity列的介紹,望你能有所收獲。
上述的相關(guān)內(nèi)容就是對(duì)SQL Server identity列的描述,希望會(huì)給你帶來一些幫助在此方面。
【編輯推薦】
- SQL Server 2005允許遠(yuǎn)程的配置流程
- 批量修改SQL Server 2005表構(gòu)架很簡(jiǎn)單!
- 對(duì)SQL Server 2005 BI的描述
- SQL Server 日期操作全接觸,嘻嘻
- SQL Server 易混淆的一些數(shù)據(jù)類型有哪些?