sql select 如何定義自增列?


今天在項目中遇到一個問題,想在存儲過程當中將查詢出來的數據放到一個臨時表中,不想create table(這人懶 ),可是臨時表中須要用到一個自增列,怎麼辦呢?只好想辦法啦  結果以下:ide

drop table #temp
SELECT id = IDENTITY(int,1,1),* INTO #TEMP FROM myTable 
select * from #temp 
spa

 

說明:id = IDENTITY(int,1,1),這句創建自增列的。其餘的也不用多說了!^_^orm

 

 

參考資料:
ci

SQL Server中,常常會用到Identity標識列,這種自增加的字段操做起來的確是比較方便。但它有時還會帶來一些麻煩。it

示例一 當表中被刪除了某些數據的時候,自增加列的編號就再也不是一個連線的數列。這種時候咱們能夠用如下方案來解決。io

SET IDENTITY_INSERT [TABLE] [ON|OFF]

容許將顯式值插入表的標識列中,當設置爲ON時,這時可能在INSERT操做時手工指定插入到標識列中的編號,同時必須在操做完成後,將IDENTITY_INSERT還原成OFF,不然下次插入的時候必須指定編號,那否則就沒法完成INSERT操做。table

示例二:當表中的記錄被所有刪除,但此時標識列的值愈來愈大的時候,若是不加以重置,它還會無休止的增加。這個時候咱們就要用到:class

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

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

相關文章
相關標籤/搜索