1、創(chuàng)建方法:
方法一:
create table TempTableName
或
select [字段1,字段2,...,] into TempTableName from table
方法二:
create table tempdb.MyTempTable(Tid int)
說明:
(1)、臨時表其實是放在數(shù)據(jù)庫tempdb里的一個用戶表;
(2)、TempTableName必須帶“#”,“#"可以是一個或者兩個,以#(局部)或##(全局)開頭的表,這種表在會話期間存在,會話結(jié)束則自動刪除;
(3)、如果創(chuàng)建時不以#或##開頭,而用tempdb.TempTable來命名它,則該表可在數(shù)據(jù)庫重啟前一直存在。
2、手動刪除
drop table TempTableName
說明:
DROP TABLE 語句顯式除去臨時表,否則臨時表將在退出其作用域時由系統(tǒng)自動除去:
(1)、當(dāng)存儲過程完成時,將自動除去在存儲過程中創(chuàng)建的本地臨時表。由創(chuàng)建表的存儲過程執(zhí)行的所有嵌套存儲過程都可以引用此表。但調(diào)用創(chuàng)建此表的存儲過程的進(jìn)程無法引用此表;
(2)、所有其它本地臨時表在當(dāng)前會話結(jié)束時自動除去;
(3)、全局臨時表在創(chuàng)建此表的會話結(jié)束且其它任務(wù)停止對其引用時自動除去。任務(wù)與表之間的關(guān)聯(lián)只在單個Transact-SQL語句的生存周期內(nèi)保持。換言之,當(dāng)創(chuàng)建全局臨時表的會話結(jié)束時,最后一條引用此表的Transact-SQL語句完成后,將自動除去此表。
3、示例代碼
(1)創(chuàng)建
use testdb--創(chuàng)建局部臨時表 create table #tmpStudent(Tid int,Name varchar(50),Age int)insert into #tmpStudent values('xiaowang',25)select * from #tmpStudent--創(chuàng)建局部臨時表 另一種寫法select * into #tmpStudent from studentselect * from #tmpStudent
第二種創(chuàng)建方法:
create table tempdb.MyTempTable(Tid int) --有對應(yīng)權(quán)限才可以這么寫
(2)刪除
drop table #tmpStudent
關(guān)于sql中臨時表的生命周期
1.局部臨時表(#開頭)只對當(dāng)前連接有效,當(dāng)前連接斷開時自動刪除。
2.全局臨時表(##開頭)對其它連接也有效,在當(dāng)前連接和其他訪問過它的連接都斷開時自動刪除。
3.不管局部臨時表還是全局臨時表,只要連接有訪問權(quán)限,都可以用drop table #Tmp(或者drop table ##Tmp)來顯式刪除
新聞熱點
疑難解答
圖片精選