SQL Server數(shù)據(jù)庫的臨時表的正確操作步驟
下面的文章主要介紹的是SQL Server數(shù)據(jù)庫的臨時表的正確使用方案,SQL Server數(shù)據(jù)庫的臨時表在實際操作中有很多的問題需要我們大家處理,那么究竟是如何對其進行處理的呢?以下的文章將會給你相應的解答方案。
刪除臨時表#Tmp
create table #Tmp 創(chuàng)建臨時表#Tmp
(
ID int IDENTITY (1,1) not null, 創(chuàng)建列ID,并且每次新增一條記錄就會加1
WokNo varchar(50),
pr
SQL Server數(shù)據(jù)庫臨時表的使用
刪除臨時表#Tmp
create table #Tmp 創(chuàng)建臨時表#Tmp
(
ID int IDENTITY (1,1) not null, 創(chuàng)建列ID,并且每次新增一條記錄就會加1
WokNo varchar(50),
primary key (ID) 定義ID為臨時表#Tmp的主鍵
);
Select * from #Tmp 查詢臨時表的數(shù)據(jù)
truncate table #Tmp 清空臨時表的所有數(shù)據(jù)和約束
相關例子:
Declare @Wokno Varchar(500) 用來記錄職工號
Declare @Str NVarchar(4000) 用來存放查詢語句
Declare @Count int 求出總記錄數(shù)
- Declare @i int
- Set @i = 0
- Select @CountCount = 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
一行一行把職工號顯示出來
- Set @i = @i + 1
- End
臨時表
可以創(chuàng)建本地和全局臨時表。本地臨時表僅在當前會話中可見;全局臨時表在所有會話中都可見。
本地臨時表的名稱前面有一個編號符 (#table_name),而全局臨時表的名稱前面有兩個編號符 (##table_name)。
SQL 語句使用 CREATE TABLE 語句中為 table_name 指定的名稱引用臨時表:
- CREATE TABLE #MyTempTable (cola INT PRIMARY KEY)
- INSERT INTO #MyTempTable VALUES (1)
如果本地臨時表由存儲過程創(chuàng)建或由多個用戶同時執(zhí)行的應用程序創(chuàng)建,則 SQL Server數(shù)據(jù)庫必須能夠區(qū)分由不同用戶創(chuàng)建的表。為此,SQL Server 在內(nèi)部為每個本地臨時表的表名追
加一個數(shù)字后綴。存儲在 tempdb 數(shù)據(jù)庫的 sysobjects 表中的臨時表,其全名由 CREATE TABLE 語句中指定的表名和系統(tǒng)生成的數(shù)字后綴組成。為了允許追加后綴,為本地臨時表指定的表名 table_name 不能超過 116 個字符。
除非使用 DROP TABLE 語句顯式除去臨時表,否則臨時表將在退出其作用域時由系統(tǒng)自動除去:
當存儲過程完成時,將自動除去在存儲過程中創(chuàng)建的本地臨時表。由創(chuàng)建表的存儲過程執(zhí)行的所有嵌套存儲過程都可以引用此表。但調用創(chuàng)建此表的存儲過程的進程無法引用此表。所有其它本地臨時表在當前會話結束時自動除去。
全局臨時表在創(chuàng)建此表的會話結束且其它任務停止對其引用時自動除去。任務與表之間的關聯(lián)只在單個 Transact-SQL 語句的生存周期內(nèi)保持。換言之,當創(chuàng)建全局臨時表的會話結束時,***一條引用此表的 Transact-SQL 語句完成后,將自動除去此表。
在存儲過程或觸發(fā)器中創(chuàng)建的本地臨時表與在調用存儲過程或觸發(fā)器之前創(chuàng)建的同名臨時表不同。如果查詢引用臨時表,而同時有兩個同名的臨時表,則不定義針對哪個表解析該查詢。嵌套存儲過程同樣可以創(chuàng)建與調用它的存儲過程所創(chuàng)建的臨時表同名的臨時表。嵌套存儲過程中對表名的所有引用都被解釋為是針對該嵌套過程所創(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
下面是結果集:
- (1 row(s) affected)
- Test1Col
- 1
- (1 row(s) affected)
- Test2Col
- 2
當創(chuàng)建本地或全局臨時表時,CREATE TABLE 語法支持除 FOREIGN KEY 約束以外的其它所有約束定義。如果在臨時表中指定 FOREIGN KEY 約束,該語句將返回警告信息,指出此約
束已被忽略,表仍會創(chuàng)建,但不具有 FOREIGN KEY 約束。在 FOREIGN KEY 約束中不能引用臨時表。
考慮使用表變量而不使用SQL Server數(shù)據(jù)庫臨時表。當需要在臨時表上顯式地創(chuàng)建索引時,或多個存儲過程或函數(shù)需要使用表值時,臨時表很有用。通常,表變量提供更有效的查詢處理。
【編輯推薦】
- SQL Server內(nèi)存占用的執(zhí)行緩存的正確優(yōu)化
- SQL Server所有表的列信息展示
- SQL Server 數(shù)據(jù)表信息的詳細描述
- SQL Server數(shù)據(jù)庫附加之后只讀或是失敗的破解
- SQL Server置疑的出現(xiàn)的原因,現(xiàn)象與破解