濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > sql server 臨時(shí)表 查找并刪除的實(shí)現(xiàn)代碼

sql server 臨時(shí)表 查找并刪除的實(shí)現(xiàn)代碼

熱門標(biāo)簽:分享百度地圖標(biāo)注多個(gè)位置 菏澤語音電銷機(jī)器人加盟公司 知名電銷機(jī)器人價(jià)格 地圖標(biāo)注牌 湖南電腦外呼系統(tǒng)平臺(tái) 長(zhǎng)沙智能外呼系統(tǒng) 電銷機(jī)器人公司 需要哪些牌照 廣東防封卡外呼系統(tǒng)原理是什么 外呼系統(tǒng)改進(jìn)
if exists(select * from tempdb..sysobjects where id=object_id('tempdb..#temp'))
drop table #temp
臨時(shí)表
可以創(chuàng)建本地和全局臨時(shí)表。本地臨時(shí)表僅在當(dāng)前會(huì)話中可見;全局臨時(shí)表在所有會(huì)話中都可見。
本地臨時(shí)表的名稱前面有一個(gè)編號(hào)符 (#table_name),而全局臨時(shí)表的名稱前面有兩個(gè)編號(hào)符 (##table_name)。
SQL 語句使用 CREATE TABLE 語句中為 table_name 指定的名稱引用臨時(shí)表:
CREATE TABLE #MyTempTable (cola INT PRIMARY KEY)
INSERT INTO #MyTempTable VALUES (1)
如果本地臨時(shí)表由存儲(chǔ)過程創(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ù)庫的 sysobjects 表中的臨時(shí)表,其全名由 CREATE TABLE 語句中指定的表名和系統(tǒng)生成的數(shù)字后綴組成。為了允許追加后綴,為本地臨時(shí)表指定的表名 table_name 不能超過 116 個(gè)字符。
除非使用 DROP TABLE 語句顯式除去臨時(shí)表,否則臨時(shí)表將在退出其作用域時(shí)由系統(tǒng)自動(dòng)除去:
當(dāng)存儲(chǔ)過程完成時(shí),將自動(dòng)除去在存儲(chǔ)過程中創(chuàng)建的本地臨時(shí)表。由創(chuàng)建表的存儲(chǔ)過程執(zhí)行的所有嵌套存儲(chǔ)過程都可以引用此表。但調(diào)用創(chuàng)建此表的存儲(chǔ)過程的進(jìn)程無法引用此表。
所有其它本地臨時(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 語句的生存周期內(nèi)保持。換言之,當(dāng)創(chuàng)建全局臨時(shí)表的會(huì)話結(jié)束時(shí),最后一條引用此表的 Transact-SQL 語句完成后,將自動(dòng)除去此表。
在存儲(chǔ)過程或觸發(fā)器中創(chuàng)建的本地臨時(shí)表與在調(diào)用存儲(chǔ)過程或觸發(fā)器之前創(chuàng)建的同名臨時(shí)表不同。如果查詢引用臨時(shí)表,而同時(shí)有兩個(gè)同名的臨時(shí)表,則不定義針對(duì)哪個(gè)表解析該查詢。嵌套存儲(chǔ)過程同樣可以創(chuàng)建與調(diào)用它的存儲(chǔ)過程所創(chuàng)建的臨時(shí)表同名的臨時(shí)表。嵌套存儲(chǔ)過程中對(duì)表名的所有引用都被解釋為是針對(duì)該嵌套過程所創(chuàng)建的表,例如:
復(fù)制代碼 代碼如下:

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 語法支持除 FOREIGN KEY 約束以外的其它所有約束定義。如果在臨時(shí)表中指定 FOREIGN KEY 約束,該語句將返回警告信息,指出此約束已被忽略,表仍會(huì)創(chuàng)建,但不具有 FOREIGN KEY 約束。在 FOREIGN KEY 約束中不能引用臨時(shí)表。
考慮使用表變量而不使用臨時(shí)表。當(dāng)需要在臨時(shí)表上顯式地創(chuàng)建索引時(shí),或多個(gè)存儲(chǔ)過程或函數(shù)需要使用表值時(shí),臨時(shí)表很有用。通常,表變量提供更有效的查詢處理。
您可能感興趣的文章:
  • SQLServer中臨時(shí)表與表變量的區(qū)別分析
  • sql server創(chuàng)建臨時(shí)表的兩種寫法和刪除臨時(shí)表
  • sqlserver 臨時(shí)表的用法
  • sql server中判斷表或臨時(shí)表是否存在的方法
  • sqlserver 臨時(shí)表 Vs 表變量 詳細(xì)介紹
  • SQL Server 向臨時(shí)表插入數(shù)據(jù)示例
  • sqlserver 動(dòng)態(tài)創(chuàng)建臨時(shí)表的語句分享
  • SQL Server 表變量和臨時(shí)表的區(qū)別(詳細(xì)補(bǔ)充篇)
  • sql server 創(chuàng)建臨時(shí)表的使用說明
  • SQL SERVER臨時(shí)表排序問題的解決方法

標(biāo)簽:福建 呼和浩特 珠海 泉州 西寧 天水 美容院 商洛

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sql server 臨時(shí)表 查找并刪除的實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  sql,server,臨時(shí),表,查找,并,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sql server 臨時(shí)表 查找并刪除的實(shí)現(xiàn)代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于sql server 臨時(shí)表 查找并刪除的實(shí)現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    瑞安市| 内江市| 宜丰县| 南雄市| 凤城市| 调兵山市| 延庆县| 澳门| 仲巴县| 象山县| 会东县| 浏阳市| 股票| 八宿县| 垣曲县| 浦东新区| 丰都县| 周口市| 镶黄旗| 大邑县| 信宜市| 靖远县| 凯里市| 中卫市| 揭阳市| 成都市| 永寿县| 卓资县| 蒙自县| 桂东县| 宁强县| 黑龙江省| 汕尾市| 阜新市| 塘沽区| 越西县| 安泽县| 布拖县| 怀宁县| 浦县| 宜黄县|