有關identity的小技巧
SQL Server中,經常會用到Identity標識列,這種自增長的欄位操作起來的確是比較方便。但它有時還會帶來一些麻煩。
示例一 :當表中被刪除了某些資料的時候,自增長列的編號就不再是一個連線的數列。這種時候我們可以用以下方案來解決。
SET IDENTITY_INSERT [TABLE] [ON|OFF]
允許將顯式值插入表的標識列中,當設定為ON時,這時可能在INSERT操作時手工指定插入到標識列中的編號,同時必須在操作完成後,將IDENTITY_INSERT還原成OFF,否則下次插入的時候必須指定編號,那不然就無法完成INSERT操作。
示例二:當表中的記錄被全部刪除,但此時標識列的值越來越大的時候,如果不加以重置,它還會無休止的增長。這個時候我們就要用到:
DBCC CHECKIDENT(TABLE, [RESEED|NORESEED], [1])
將把指定表的種子值強制重設為1。然而,你可能不想將種子重設為1,在這種情況下,你可以用你想用的種子值替代第三個引數。有時候你可能想知道當前的種子,而不是想重設種子,這時你就要用到NORESEED,而不用再去顧忌第三個引數。
示例一 :當表中被刪除了某些資料的時候,自增長列的編號就不再是一個連線的數列。這種時候我們可以用以下方案來解決。
SET IDENTITY_INSERT [TABLE] [ON|OFF]
允許將顯式值插入表的標識列中,當設定為ON時,這時可能在INSERT操作時手工指定插入到標識列中的編號,同時必須在操作完成後,將IDENTITY_INSERT還原成OFF,否則下次插入的時候必須指定編號,那不然就無法完成INSERT操作。
示例二:當表中的記錄被全部刪除,但此時標識列的值越來越大的時候,如果不加以重置,它還會無休止的增長。這個時候我們就要用到:
DBCC CHECKIDENT(TABLE, [RESEED|NORESEED], [1])
將把指定表的種子值強制重設為1。然而,你可能不想將種子重設為1,在這種情況下,你可以用你想用的種子值替代第三個引數。有時候你可能想知道當前的種子,而不是想重設種子,這時你就要用到NORESEED,而不用再去顧忌第三個引數。
相關文章
- 30個有關Python的小技巧Python
- 有關連結串列的小技巧,我都給你總結好了
- 8個關於Python的小技巧Python
- 關於Mac廢紙簍的小技巧!Mac
- 關於identity列的探討IDE
- [小技巧]Laravel 關聯儲存Laravel
- 關於Win10的10個小技巧Win10
- 關閉 Ubuntu 中的關機/重啟確認的小技巧Ubuntu
- iOS 小技巧總結,絕對有你想要的iOS
- 【vuejs】有關vue的一些小技巧VueJS
- 關鍵業務系統的最佳化小技巧
- 有哪些確保雲伺服器安全的小技巧?伺服器
- 10. IDENTITY屬性使用小結IDE
- 關於使用iview中Table元件的一點小技巧View元件
- 關閉Mac上煩人的通知之小技巧分享Mac
- FineUI小技巧(4)關閉窗體那些事UI
- 有關mysql中ROW_COUNT()的小例子MySql
- 有關Es6知識的小結
- C 有關記憶體的小謎題記憶體
- 關於Web前端面試的小技巧,千萬不要錯過!Web前端面試
- (大表小技巧)有時候 2 小時的 SQL 操作,可能只要 1 分鐘SQL
- Mysql中的小技巧MySql
- 常用的CSS小技巧CSS
- 【js】中的小技巧JS
- 尤拉序的小技巧
- Python的小技巧Python
- 微信小程式小技巧微信小程式
- @@IDENTITY與SCOPE_IDENTITY()IDE
- 關於PHP程式設計中的變數使用技巧小結PHP程式設計變數
- 有關字串的一些好用的小函式字串函式
- 有關程式碼執行效率提升的小例子
- 1.C語言有關的小學習C語言
- Mac 小技巧Mac
- PHP 小技巧PHP
- JavaScript小技巧JavaScript
- git小技巧Git
- JavaScript?小技巧JavaScript
- css小技巧CSS