sql的臨時(shí)表使用小結(jié)
1、創(chuàng)建方法:
方法一:
create table TempTableName
或
select [字段1,字段2,...,] into TempTableName from table
方法二:
create table tempdb.MyTempTable(Tid int)
說明:
(1)、臨時(shí)表其實(shí)是放在數(shù)據(jù)庫tempdb里的一個(gè)用戶表;
(2)、TempTableName必須帶“#”,“#"可以是一個(gè)或者兩個(gè),以#(局部)或##(全局)開頭的表,這種表在會話期間存在,會話結(jié)束則自動(dòng)刪除;
(3)、如果創(chuàng)建時(shí)不以#或##開頭,而用tempdb.TempTable來命名它,則該表可在數(shù)據(jù)庫重啟前一直存在。
2、手動(dòng)刪除
drop table TempTableName
說明:
DROP TABLE 語句顯式除去臨時(shí)表,否則臨時(shí)表將在退出其作用域時(shí)由系統(tǒng)自動(dòng)除去:
(1)、當(dāng)存儲過程完成時(shí),將自動(dòng)除去在存儲過程中創(chuàng)建的本地臨時(shí)表。由創(chuàng)建表的存儲過程執(zhí)行的所有嵌套存儲過程都可以引用此表。但調(diào)用創(chuàng)建此表的存儲過程的進(jìn)程無法引用此表;
(2)、所有其它本地臨時(shí)表在當(dāng)前會話結(jié)束時(shí)自動(dòng)除去;
(3)、全局臨時(shí)表在創(chuàng)建此表的會話結(jié)束且其它任務(wù)停止對其引用時(shí)自動(dòng)除去。任務(wù)與表之間的關(guān)聯(lián)只在單個(gè)Transact-SQL語句的生存周期內(nèi)保持。換言之,當(dāng)創(chuàng)建全局臨時(shí)表的會話結(jié)束時(shí),最后一條引用此表的Transact-SQL語句完成后,將自動(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) --有對應(yīng)權(quán)限才可以這么寫
(2)刪除
drop table #tmpStudent
關(guān)于sql中臨時(shí)表的生命周期
1.局部臨時(shí)表(#開頭)只對當(dāng)前連接有效,當(dāng)前連接斷開時(shí)自動(dòng)刪除。
2.全局臨時(shí)表(##開頭)對其它連接也有效,在當(dāng)前連接和其他訪問過它的連接都斷開時(shí)自動(dòng)刪除。
3.不管局部臨時(shí)表還是全局臨時(shí)表,只要連接有訪問權(quán)限,都可以用drop table #Tmp(或者drop table ##Tmp)來顯式刪除
相關(guān)文章
解決SQL SERVER數(shù)據(jù)庫備份時(shí)出現(xiàn)“操作系統(tǒng)錯(cuò)誤5(拒絕訪問)。BACKUP DATABASE 正在異常終止?!卞e(cuò)
這篇文章主要介紹了SQL SERVER數(shù)據(jù)庫備份時(shí)出現(xiàn)“操作系統(tǒng)錯(cuò)誤5(拒絕訪問)。BACKUP DATABASE 正在異常終止?!卞e(cuò)誤的解決辦法,需要的朋友可以參考下2015-08-08將Reporting services的RDL文件拷貝到另外一臺機(jī)器時(shí)報(bào)Data at the root level i
在本機(jī)開發(fā)了一個(gè)Reporting后拷貝到服務(wù)器,然后在Sql Server Business Intelligence Development Studio中添加再打開后會報(bào)Data at the root level is invalid.錯(cuò)誤2012-06-06SQL Server數(shù)據(jù)庫定時(shí)自動(dòng)備份
這篇文章主要為大家詳細(xì)介紹了SQL Server數(shù)據(jù)庫定時(shí)自動(dòng)備份的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03mybatis collection 多條件查詢的實(shí)現(xiàn)方法
這篇文章主要介紹了mybatis collection 多條件查詢的實(shí)現(xiàn)方法的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-10-10Oracle、MySQL和SqlServe三種數(shù)據(jù)庫分頁查詢語句的區(qū)別介紹
這篇文章主要介紹了Oracle、MySQL和SqlServe三種數(shù)據(jù)庫分頁查詢語句的區(qū)別介紹 的相關(guān)資料,需要的朋友可以參考下2016-05-05命令行啟動(dòng)mssqlserver服務(wù)的方法示例
這篇文章主要介紹了命令行啟動(dòng)mssqlserver服務(wù)的方法,大家參考使用2013-11-11