自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

帶您了解sql server臨時表

數(shù)據(jù)庫 SQL Server
sql server數(shù)據(jù)庫中,可以創(chuàng)建本地和全局臨時表,兩種臨時表有所不同,下面就將為您介紹這兩種臨時表的使用方法,供您參考。

sql server臨時表分為本地臨時表和全局臨時表,下面為您詳細(xì)介紹這兩種sql server臨時表,如果您對sql server臨時表方面感興趣的話,不妨一看。

可以創(chuàng)建本地和全局臨時表。本地臨時表僅在當(dā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í)行的應(yīng)用程序創(chuàng)建,則 SQL Server 必須能夠區(qū)分由不同用戶創(chuàng)建的表。為此,SQL Server 在內(nèi)部為每個本地臨時表的表名追加一個數(shù)字后綴。存儲在 tempdb 數(shù)據(jù)庫的 sysobjects 表中的臨時表,其全名由 CREATE TABLE 語句中指定的表名和系統(tǒng)生成的數(shù)字后綴組成。為了允許追加后綴,為本地臨時表指定的表名 table_name 不能超過 116 個字符。

除非使用 DROP TABLE 語句顯式除去sql server臨時表,否則sql server臨時表將在退出其作用域時由系統(tǒng)自動除去:

當(dāng)存儲過程完成時,將自動除去在存儲過程中創(chuàng)建的本地臨時表。由創(chuàng)建表的存儲過程執(zhí)行的所有嵌套存儲過程都可以引用此表。但調(diào)用創(chuàng)建此表的存儲過程的進(jìn)程無法引用此表。

所有其它本地臨時表在當(dāng)前會話結(jié)束時自動除去。

全局臨時表在創(chuàng)建此表的會話結(jié)束且其它任務(wù)停止對其引用時自動除去。任務(wù)與表之間的關(guān)聯(lián)只在單個 Transact-SQL 語句的生存周期內(nèi)保持。換言之,當(dāng)創(chuàng)建全局臨時表的會話結(jié)束時,***一條引用此表的 Transact-SQL 語句完成后,將自動除去此表。
在存儲過程或觸發(fā)器中創(chuàng)建的本地臨時表與在調(diào)用存儲過程或觸發(fā)器之前創(chuàng)建的同名臨時表不同。如果查詢引用臨時表,而同時有兩個同名的sql server臨時表,則不定義針對哪個表解析該查詢。嵌套存儲過程同樣可以創(chuàng)建與調(diào)用它的存儲過程所創(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

下面是結(jié)果集:

(1 row(s) affected)

Test1Col   
-----------
1          

(1 row(s) affected)

Test2Col   
-----------
2          

當(dāng)創(chuàng)建本地或全局臨時表時,CREATE TABLE 語法支持除 FOREIGN KEY約束以外的其它所有約束定義。如果在臨時表中指定 FOREIGN KEY 約束,該語句將返回警告信息,指出此約束已被忽略,表仍會創(chuàng)建,但不具有 FOREIGN KEY 約束。在 FOREIGN KEY 約束中不能引用臨時表。

考慮使用表變量而不使用臨時表。當(dāng)需要在臨時表上顯式地創(chuàng)建索引時,或多個存儲過程或函數(shù)需要使用表值時,臨時表很有用。通常,表變量提供更有效的查詢處理。

 
 

 

 

【編輯推薦】

SQL SERVER恢復(fù)的方法

帶您深入了解SQL Server事務(wù)

SQL Server定時作業(yè)的設(shè)置方法

SQL Server連接錯誤的解決方法

25條mysql和sql server區(qū)別

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-09-16 14:38:55

Sql server表

2010-10-27 15:58:01

Oracle臨時表

2010-10-15 11:27:21

Mysql臨時表

2010-10-22 13:34:49

SQL Server游

2010-10-21 15:07:09

SQL Server系

2010-11-12 11:07:03

sql server內(nèi)

2010-10-20 15:02:21

2010-10-20 10:31:57

sql server聯(lián)

2010-11-11 11:56:39

SQL Server標(biāo)

2010-10-19 13:26:45

SQL Server事

2010-10-21 11:44:55

SQL Server分

2010-10-20 16:22:52

SQL Server權(quán)

2010-11-12 14:55:59

Sql Server檢

2010-10-22 11:10:43

SQL Server觸

2010-11-08 11:49:24

SQL Server管

2010-11-29 10:48:49

Sybase系統(tǒng)表

2010-09-26 14:40:25

SQL FROM子句

2010-09-26 14:12:35

SQL內(nèi)連接

2010-10-21 15:46:05

SQL Server服

2010-10-19 16:48:23

Sql Server日
點贊
收藏

51CTO技術(shù)棧公眾號