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

對(duì)SQL Server臨時(shí)表的“素描”

數(shù)據(jù)庫(kù) SQL Server
以下的文章主要描述的是SQL Server臨時(shí)表,如果你對(duì)SQL Server臨時(shí)表有興趣了解的話,以下的文章將會(huì)為你提供相關(guān)知識(shí)。

此文章主要介紹的是SQL Server臨時(shí)表,你對(duì)SQL Server臨時(shí)表實(shí)際操作感到十分頭疼?別急,以下的文章將會(huì)給你相應(yīng)的解決方案,以下的文章主要是介紹獲得Oracle權(quán)限的方案,以下就是相關(guān)內(nèi)容的具體描述。

可以創(chuàng)建本地和全局臨時(shí)表。本地臨時(shí)表僅在當(dāng)前會(huì)話中可見(jiàn);全局臨時(shí)表在所有會(huì)話中都可見(jiàn)。本地臨時(shí)表的名稱前面有一個(gè)編號(hào)符 (#table_name),而全局臨時(shí)表的名稱前面有兩個(gè)編號(hào)符 (##table_name)。

SQL 語(yǔ)句使用 CREATE TABLE 語(yǔ)句中為 table_name 指定的名稱引用SQL Server臨時(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 表中的SQL Server臨時(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í)表同名的SQL Server臨時(shí)表。

嵌套存儲(chǔ)過(guò)程中對(duì)表名的所有引用都被解釋為是針對(duì)該嵌套過(guò)程所創(chuàng)建的表,例如:

 

  1. CREATE PROCEDURE Test2ASCREATE TABLE  
  2. #t(x INT PRIMARY KEY)INSERT INTO   
  3. #t VALUES (2)SELECT Test2Col = x FROM  
  4. #tGOCREATE PROCEDURE Test1ASCREATE TABLE  
  5. #t(x INT PRIMARY KEY)INSERT INTO   
  6. #t VALUES (1)SELECT Test1Col = x FROM #tEXEC Test2GOCREATE TABLE  
  7. #t(x INT PRIMARY KEY)INSERT INTO   
  8. #t VALUES (99)GOEXEC Test1GO   

 

下面是結(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 約束中不能引用SQL Server臨時(shí)表??紤]使用表變量而不使用臨時(shí)表。當(dāng)需要在臨時(shí)表上顯式地創(chuàng)建索引時(shí),或多個(gè)存儲(chǔ)過(guò)程或函數(shù)需要使用表值時(shí),臨時(shí)表很有用。通常,表變量提供更有效的查詢處理。

【編輯推薦】

  1. 對(duì)MS SQL Server函數(shù)的兩種實(shí)際用法的分析
  2. SQL Server安全門的正確構(gòu)造的流程
  3. SQL Server數(shù)據(jù)庫(kù)的收縮與設(shè)定每日自動(dòng)備份
  4. 轉(zhuǎn)移SQL Server數(shù)據(jù)的實(shí)現(xiàn)
  5. SQL Server還原數(shù)據(jù)庫(kù)操作步驟的詳細(xì)解析
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2010-09-16 15:03:10

SQL Server臨

2010-09-16 17:56:31

SQL server臨

2010-10-19 14:45:01

SQL SERVER臨

2010-07-22 16:02:29

2010-10-19 15:25:05

Sql Server臨

2021-01-18 05:23:14

SQL 排序Server

2011-03-29 13:22:07

SQL Server臨時(shí)表表變量

2010-09-16 15:10:48

SQL Server表

2011-09-02 14:45:43

Oracle臨時(shí)表SQL Server臨

2010-07-22 15:56:04

SQL Server臨

2010-10-19 14:56:05

sql server臨

2010-09-02 16:28:03

SQL刪除

2010-07-01 14:46:10

SQL Server臨

2010-11-11 10:41:03

sql server遍

2010-07-01 14:11:40

SQL Server內(nèi)

2009-03-18 10:56:29

生命周期全局臨時(shí)表SQL Server

2010-07-22 16:07:02

SQL Server數(shù)

2010-07-08 14:24:21

SQL Server

2010-10-19 15:31:40

sql server觸

2010-07-26 13:56:38

SQL Server臨
點(diǎn)贊
收藏

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