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