sql server 創(chuàng)建臨時(shí)表的使用說(shuō)明
臨時(shí)表產(chǎn)生:A: SELECT INTO和B:CREATE TABLE + INSERT INTO
1. A 要比B 快很多。但是A會(huì)鎖定tempdb的SYSOBJECTS、SYSINDEXES、SYSCOLUMNS表,在多用戶并發(fā)的時(shí)候,容易產(chǎn)生阻塞其他的進(jìn)程。
2. 在并發(fā)系統(tǒng)中是用B. 大數(shù)量的單個(gè)語(yǔ)句中,使用A.
創(chuàng)建臨時(shí)表的方法:
方法一:
create table #臨時(shí)表名(字段1 約束條件,
字段2 約束條件,
.....)
create table ##臨時(shí)表名(字段1 約束條件,
字段2 約束條件,
.....)
方法二:
select * into #臨時(shí)表名 from 你的表;
select * into ##臨時(shí)表名 from 你的表;
注:以上的#代表局部臨時(shí)表,##代表全局臨時(shí)表
查詢臨時(shí)表
select * from #臨時(shí)表名;
select * from ##臨時(shí)表名;
刪除臨時(shí)表
drop table #臨時(shí)表名;
drop table ##臨時(shí)表名;
SQL SERVER臨時(shí)表的使用
drop table #Tmp --刪除臨時(shí)表#Tmp create table #Tmp --創(chuàng)建臨時(shí)表#Tmp ( ID int IDENTITY (1,1) not null, --創(chuàng)建列ID,并且每次新增一條記錄就會(huì)加1 WokNo varchar(50), primary key (ID) --定義ID為臨時(shí)表#Tmp的主鍵 ); Select * from #Tmp --查詢臨時(shí)表的數(shù)據(jù) truncate table #Tmp --清空臨時(shí)表的所有數(shù)據(jù)和約束
相關(guān)例子:
Declare @Wokno Varchar(500) --用來(lái)記錄職工號(hào)
Declare @Str NVarchar(4000) --用來(lái)存放查詢語(yǔ)句
Declare @Count int --求出總記錄數(shù)
Declare @i int
Set @i = 0
Select @Count = Count(Distinct(Wokno)) from #Tmp
While @i < @Count
Begin
Set @Str = 'Select top 1 @Wokno = WokNo from #Tmp Where id not in (Select top ' + Str(@i) + 'id from #Tmp)'
Exec Sp_ExecuteSql @Str,N'@WokNo Varchar(500) OutPut',@WokNo Output
Select @WokNo,@i --一行一行把職工號(hào)顯示出來(lái)
Set @i = @i + 1
End
臨時(shí)表
可以創(chuàng)建本地和全局臨時(shí)表。本地臨時(shí)表僅在當(dāng)前會(huì)話中可見;全局臨時(shí)表在所有會(huì)話中都可見。
本地臨時(shí)表的名稱前面有一個(gè)編號(hào)符 (#table_name),而全局臨時(shí)表的名稱前面有兩個(gè)編號(hào)符 (##table_name)。
SQL 語(yǔ)句使用 CREATE TABLE 語(yǔ)句中為 table_name 指定的名稱引用臨時(shí)表:
CREATE TABLE #MyTempTable (cola INT PRIMARY KEY)
INSERT INTO #MyTempTable VALUES (1)
如果本地臨時(shí)表由存儲(chǔ)過(guò)程創(chuàng)建或由多個(gè)用戶同時(shí)執(zhí)行的應(yīng)用程序創(chuàng)建,則 SQL Server 必須能夠區(qū)分由不同用戶創(chuàng)建的表。為此,SQL Server 在內(nèi)部為每個(gè)本地臨時(shí)表的表名追加一個(gè)數(shù)字后綴。存儲(chǔ)在 tempdb 數(shù)據(jù)庫(kù)的 sysobjects 表中的臨時(shí)表,其全名由 CREATE TABLE 語(yǔ)句中指定的表名和系統(tǒng)生成的數(shù)字后綴組成。為了允許追加后綴,為本地臨時(shí)表指定的表名 table_name 不能超過(guò) 116 個(gè)字符。
除非使用 DROP TABLE 語(yǔ)句顯式除去臨時(shí)表,否則臨時(shí)表將在退出其作用域時(shí)由系統(tǒng)自動(dòng)除去:
當(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ú)法引用此表。
所有其它本地臨時(shí)表在當(dāng)前會(huì)話結(jié)束時(shí)自動(dòng)除去。
全局臨時(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)除去此表。
在存儲(chǔ)過(guò)程或觸發(fā)器中創(chuàng)建的本地臨時(shí)表與在調(diào)用存儲(chǔ)過(guò)程或觸發(fā)器之前創(chuàng)建的同名臨時(shí)表不同。如果查詢引用臨時(shí)表,而同時(shí)有兩個(gè)同名的臨時(shí)表,則不定義針對(duì)哪個(gè)表解析該查詢。嵌套存儲(chǔ)過(guò)程同樣可以創(chuàng)建與調(diào)用它的存儲(chǔ)過(guò)程所創(chuàng)建的臨時(shí)表同名的臨時(shí)表。嵌套存儲(chǔ)過(guò)程中對(duì)表名的所有引用都被解釋為是針對(duì)該嵌套過(guò)程所創(chuàng)建的表,例如:
CREATE PROCEDURE Test2 AS CREATE TABLE #t(x INT PRIMARY KEY) INSERT INTO #t VALUES (2) SELECT Test2Col = x FROM #t GO CREATE PROCEDURE Test1 AS CREATE TABLE #t(x INT PRIMARY KEY) INSERT INTO #t VALUES (1) SELECT Test1Col = x FROM #t EXEC Test2 GO CREATE TABLE #t(x INT PRIMARY KEY) INSERT INTO #t VALUES (99) GO EXEC Test1 GO
下面是結(jié)果集:
(1 row(s) affected)
Test1Col
-----------
1
(1 row(s) affected)
Test2Col
-----------
2
當(dāng)創(chuàng)建本地或全局臨時(shí)表時(shí),CREATE TABLE 語(yǔ)法支持除 FOREIGN KEY 約束以外的其它所有約束定義。如果在臨時(shí)表中指定 FOREIGN KEY 約束,該語(yǔ)句將返回警告信息,指出此約束已被忽略,表仍會(huì)創(chuàng)建,但不具有 FOREIGN KEY 約束。在 FOREIGN KEY 約束中不能引用臨時(shí)表。
考慮使用表變量而不使用臨時(shí)表。當(dāng)需要在臨時(shí)表上顯式地創(chuàng)建索引時(shí),或多個(gè)存儲(chǔ)過(guò)程或函數(shù)需要使用表值時(shí),臨時(shí)表很有用。通常,表變量提供更有效的查詢處理。
相關(guān)文章
根據(jù)多條件查詢臨時(shí)表 想得到不同結(jié)果集的方法
很多情況下,需要采用多個(gè)參數(shù)來(lái)查詢一張臨時(shí)表,每個(gè)參數(shù)都要求得到不同的臨時(shí)表結(jié)果集。而往往某些參數(shù)并不對(duì)應(yīng)這張臨時(shí)表中的字段,而是對(duì)應(yīng)與該臨時(shí)表ID關(guān)聯(lián)的另一張表的字段。2009-11-11
在SQL SERVER中導(dǎo)致索引查找變成索引掃描的問(wèn)題分析
SQL Server 中什么情況會(huì)導(dǎo)致其執(zhí)行計(jì)劃從索引查找(Index Seek)變成索引掃描(Index Scan)呢? 下面從幾個(gè)方面結(jié)合上下文具體場(chǎng)景做了下測(cè)試、總結(jié)、歸納。需要的朋友可以參考下本文2015-09-09
sqlserver通用的刪除服務(wù)器上的所有相同后綴的臨時(shí)表
因?yàn)轫?xiàng)目需要,必須使用大量臨時(shí)表,因此編寫批量刪除臨時(shí)表的通用語(yǔ)句2012-05-05
SQL Server日期加減函數(shù)DATEDIFF與DATEADD用法分析
這篇文章主要介紹了SQL Server日期加減函數(shù)DATEDIFF與DATEADD用法,結(jié)合分析SQL Server使用DATEDIFF與DATEADD函數(shù)獲取常見的周、月、天等日期相關(guān)運(yùn)算技巧,需要的朋友可以參考下2017-03-03
查詢表中某字段有重復(fù)記錄個(gè)數(shù)的方法
本篇文章介紹了,查詢表中某字段有重復(fù)記錄個(gè)數(shù)的方法。需要的朋友參考下2013-04-04
sqlserver 數(shù)據(jù)庫(kù)連接字符串中的可選項(xiàng)收集
sqlserver 數(shù)據(jù)庫(kù)連接字符串中的可選項(xiàng)收集,需要的朋友可以參考下。2011-10-10

