婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 對比Oracle臨時表和SQL Server臨時表的不同點

對比Oracle臨時表和SQL Server臨時表的不同點

熱門標簽:百度地圖標注途經點 圖吧網站地圖標注 慧營銷crm外呼系統丹丹 愛客外呼系統怎么樣 山東crm外呼系統軟件 開發外呼系統 哪個400外呼系統好 地圖標注養老院 哈爾濱電話機器人銷售招聘

Oracle數據庫創建臨時表的過程以及和SQL Server臨時表的不同點的對比的相關知識是本文我們主要要介紹的內容,接下來就讓我們一起來了解一下這部分內容吧,希望能夠對您有所幫助。

1.簡介

Oracle數據庫除了可以保存永久表外,還可以建立臨時表temporary tables。這些臨時表用來保存一個會話SESSION的數據,或者保存在一個事務中需要的數據。當會話退出或者用戶提交commit和回滾rollback事務的時候,臨時表的數據自動清空,但是臨時表的結構以及元數據還存儲在用戶的數據字典中。

2.詳細介紹

Oracle臨時表分為會話級臨時表和事務級臨時表。

會話級臨時表是指臨時表中的數據只在會話生命周期之中存在,當用戶退出會話結束的時候,Oracle自動清除臨時表中數據。

事務級臨時表是指臨時表中的數據只在事務生命周期中存在。當一個事務結束(commit or rollback),Oracle自動清除臨時表中數據。

臨時表中的數據只對當前Session有效,每個Session都有自己的臨時數據,并且不能訪問其它Session的臨時表中的數據。因此,臨時表不需要DML鎖。

當一個會話結束(用戶正常退出 用戶不正常退出 ORACLE實例崩潰)或者一個事務結束的時候,Oracle對這個會話的表執行 TRUNCATE 語句清空臨時表數據.但不會清空其它會話臨時表中的數據.

你可以索引臨時表和在臨時表基礎上建立視圖.同樣,建立在臨時表上的索引也是臨時的,也是只對當前會話或者事務有效. 臨時表可以擁有觸發器.

3.建立臨時表

臨時表的定義對所有會話SESSION都是可見的,但是表中的數據只對當前的會話或者事務有效.

建立方法:

1) ON COMMIT DELETE ROWS 定義了建立事務級臨時表的方法. 
CREATE GLOBAL TEMPORARY TABLE admin_work_area 
(startdate DATE, 
enddate DATE, 
class CHAR(20)) 
ON COMMIT DELETE ROWS; 
EXAMPLE: 
SQL> CREATE GLOBAL TEMPORARY TABLE admin_work_area 
2 (startdate DATE, 
3 enddate DATE, 
4 class CHAR(20)) 
5 ON COMMIT DELETE ROWS; 
SQL> create table permernate( a number); 
SQL> insert into admin_work_area values(sysdate,sysdate,'temperary table'); 
SQL> insert into permernate values(1); 
SQL> commit; 
SQL> select * from admin_work_area; 
SQL> select * from permernate; 
A 
1 
2)ON COMMIT PRESERVE ROWS 定義了創建會話級臨時表的方法. 
CREATE GLOBAL TEMPORARY TABLE admin_work_area 
(startdate DATE, 
enddate DATE, 
class CHAR(20)) 
ON COMMIT PRESERVE ROWS; 
EXAMPLE: 

會話1:

SQL> drop table admin_work_area; 
SQL> CREATE GLOBAL TEMPORARY TABLE admin_work_area 
2 (startdate DATE, 
3 enddate DATE, 
4 class CHAR(20)) 
5 ON COMMIT PRESERVE ROWS; 
SQL> insert into permernate values(2); 
SQL> insert into admin_work_area values(sysdate,sysdate,'session temperary'); 
SQL> commit; 
SQL> select * from permernate; 
A 
---------- 
1 
2 
SQL> select * from admin_work_area; 
STARTDATE ENDDATE CLASS 
---------- ---------- -------------------- 
17-1?? -03 17-1?? -03 session temperary 

會話2:

SQL> select * from permernate; 
A 
---------- 
1 
2 
SQL> select * from admin_work_area; 
未選擇行. 

會話2看不見會話1中臨時表的數據。

4.Oracle臨時表和SQL Server臨時表異同

SQL Server也可以創建臨時表。臨時表與永久表相似,但臨時表存儲在tempdb中,當不再使用時會自動刪除。

有本地和全局兩種類型的臨時表,二者在名稱、可見性和可用性上均不相同。本地臨時表的名稱以單個數字符號 (#) 打頭;它們僅對當前的用戶連接是可見的;當用戶從 Microsoft SQL Server實例斷開連接時被刪除。全局臨時表的名稱以數學符號 (##) 打頭,創建后對任何用戶都是可見的,當所有引用該表的用戶從 SQL Server 斷開連接時被刪除。

SQL 語句使用 CREATE TABLE 語句中為 table_name 指定的名稱引用臨時表:

CREATE TABLE #MyTempTable (cola INT PRIMARY KEY) 
INSERT INTO #MyTempTable VALUES (1) 

如果本地臨時表由存儲過程創建或由多個用戶同時執行的應用程序創建,則 SQL Server 必須能夠區分由不同用戶創建的表。為此,SQL Server 在內部為每個本地臨時表的表名追加一個數字后綴。存儲在 tempdb 數據庫的 sysobjects 表中的臨時表,其全名由 CREATE TABLE 語句中指定的表名和系統生成的數字后綴組成。為了允許追加后綴,為本地臨時表指定的表名 table_name 不能超過116 個字符。

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

當存儲過程完成時,將自動除去在存儲過程中創建的本地臨時表。由創建表的存儲過程執行的所有嵌套存儲過程都可以引用此表。但調用創建此表的存儲過程的進程無法引用此表。

所有其它本地臨時表在當前會話結束時自動除去。

全局臨時表在創建此表的會話結束且其它任務停止對其引用時自動除去。任務與表之間的關聯只在單個 Transact-SQL 語句的生存周期內保持。換言之,當創建全局臨時表的會話結束時,最后一條引用此表的Transact-SQL語句完成后,將自動除去此表。

例如,如果創建名為 employees 的表,則任何人只要在數據庫中有使用該表的安全權限就可以使用該表,除非它已刪除。如果創建名為 #employees 的本地臨時表,只有您能對該表執行操作且在斷開連接時該表刪除。如果創建名為 ##employees 的全局臨時表,數據庫中的任何用戶均可對該表執行操作。如果該表在您創建后沒有其他用戶使用,則當您斷開連接時該表刪除。如果該表在您創建后有其他用戶使用,則 SQL Server在所有用戶斷開連接后刪除該表。

在存儲過程或觸發器中創建的本地臨時表與在調用存儲過程或觸發器之前創建的同名臨時表不同。如果查詢引用臨時表,而同時有兩個同名的臨時表,則不定義針對哪個表解析該查詢。嵌套存儲過程同樣可以創建與調用它的存儲過程所創建的臨時表同名的臨時表。嵌套存儲過程中對表名的所有引用都被解釋為是針對該嵌套過程所創建的表,例如:

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 

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

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

和Oracle的不同點:

1. SQL Server臨時表是一種”內存表”,表是存儲在內存中的.ORACLE臨時表除非執行DROP TABLE,否則表定義會保留在數據字典中。

2. SQL Server臨時表不存在類似ORACLE臨時表事務級別上的功能。

3.SQL Server本地臨時表(#) 與 ORACLE的會話級別臨時表類似,但是在會話退出的時候,ORACLE不會刪除表。

4.SQL Server的全局臨時表(##) 是指多個連接共享同一片內存.當沒有指針引用該內存區域時,SQL Server自動釋放全局臨時表。

5.由于Oracle不是一種內存中的數據庫. 所以如果Oracle類似SQL Server 頻繁的對臨時表進行建立和刪除,必定會影響性能.所以Oracle會保留臨時表的定義直到用戶DROP TABLE。

6.在Oracle中,如果需要多個用戶共享一個表(類似SQL Server的全局臨時表##).則可以利用永久表,并且在表中添加一些可以唯一標識用戶的列.利用觸發器和視圖.當用戶退出的時候,根據該登陸用戶的唯一信息刪除相應的表中的數據. 這種方法給Oracle帶來了一定量的負載。

關于Oracle臨時表和SQL Server臨時表的不同點對比的相關知識就介紹到這里了,希望本次的介紹能夠對您有所收獲!

您可能感興趣的文章:
  • Oracle 12CR2查詢轉換教程之臨時表轉換詳解
  • Oracle 12CR2查詢轉換教程之cursor-duration臨時表詳解
  • oracle 臨時表詳解及實例
  • Oracle 臨時表空間SQL語句的實現

標簽:甘肅 青島 武漢 開封 周口 承德 和田 固原

巨人網絡通訊聲明:本文標題《對比Oracle臨時表和SQL Server臨時表的不同點》,本文關鍵詞  對比,Oracle,臨時,表,和,SQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《對比Oracle臨時表和SQL Server臨時表的不同點》相關的同類信息!
  • 本頁收集關于對比Oracle臨時表和SQL Server臨時表的不同點的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产日本一区二区| 91一区二区三区在线播放| 亚洲二区在线观看| 洋洋成人永久网站入口| 中文字幕一区二区三区不卡在线 | 欧美经典三级视频一区二区三区| 欧美日韩精品高清| 欧美日韩免费一区二区三区视频 | 岛国av在线一区| 91丝袜美腿高跟国产极品老师| 99国产精品久久| 欧美婷婷六月丁香综合色| 欧美一区二区三区四区在线观看| 欧美日韩在线直播| 日本一二三不卡| 亚洲精品国产精华液| 蜜臀av性久久久久av蜜臀妖精| 美女久久久精品| 北条麻妃一区二区三区| 91精品国产综合久久小美女| 久久精品免费在线观看| 综合久久综合久久| 粉嫩欧美一区二区三区高清影视| 99久久亚洲一区二区三区青草 | 久久久美女艺术照精彩视频福利播放| 久久久久久久电影| 全国精品久久少妇| 91国偷自产一区二区三区成为亚洲经典| 欧美一区二区三区在| 一区二区三区在线高清| 不卡一二三区首页| 国产网红主播福利一区二区| 日韩成人一区二区三区在线观看| 色欲综合视频天天天| 国产精品女主播在线观看| 国产又黄又大久久| 精品99一区二区| 免费观看久久久4p| 欧美电影精品一区二区| 极品少妇xxxx偷拍精品少妇| 精品乱码亚洲一区二区不卡| 亚洲线精品一区二区三区| 欧美美女bb生活片| 奇米影视一区二区三区小说| 精品日韩在线观看| 国产传媒欧美日韩成人| 久久嫩草精品久久久久| 成人中文字幕电影| 日韩av一二三| 精品剧情v国产在线观看在线| 国产精品一线二线三线| 国产精品久久久久久久久图文区 | 国产精品一区一区| 中文字幕一区在线观看视频| 欧美日韩亚洲综合在线 | 精品一区二区三区免费| 成人免费在线视频观看| 7777精品伊人久久久大香线蕉 | 亚洲大片免费看| 久久久综合网站| 日韩一级二级三级| 91免费观看国产| 国产精品亚洲午夜一区二区三区| 亚洲综合网站在线观看| 欧美国产一区在线| 精品美女在线观看| 日韩一区二区三区视频在线观看| 国产寡妇亲子伦一区二区| 亚洲卡通动漫在线| 99国产精品久久久久久久久久久| 午夜欧美电影在线观看| 亚洲激情图片小说视频| 成人欧美一区二区三区白人| 国产亚洲欧美中文| 久久综合色之久久综合| 精品国产一区二区三区久久久蜜月 | 另类小说图片综合网| 日日摸夜夜添夜夜添国产精品| 国产精品久99| 亚洲综合色成人| 午夜激情一区二区| 激情综合色综合久久综合| 精品中文字幕一区二区小辣椒| 激情五月婷婷综合| 99精品热视频| 欧美视频在线一区| 日韩欧美另类在线| 日韩毛片高清在线播放| 日韩成人免费在线| 久久成人免费电影| 日本二三区不卡| 久久人人爽人人爽| 五月天亚洲婷婷| 色呦呦日韩精品| 亚洲精品一区二区在线观看| 国产精品美女久久久久高潮| 午夜久久电影网| 色婷婷久久久综合中文字幕| 欧美一级高清片在线观看| 亚洲天堂免费在线观看视频| 青娱乐精品在线视频| 欧美日韩国产经典色站一区二区三区| 国产午夜亚洲精品理论片色戒| 亚洲国产aⅴ天堂久久| 成人免费视频视频| 国产日产欧美精品一区二区三区| 亚洲国产精品麻豆| 欧美日韩亚洲高清一区二区| 国产日韩欧美a| 美女性感视频久久| 精品国产一区二区精华| 日韩国产高清在线| 日韩免费观看高清完整版| 日韩高清欧美激情| 欧美大黄免费观看| 麻豆免费精品视频| 久久色成人在线| 成人污污视频在线观看| 国产精品视频yy9299一区| 国产黄色精品视频| 日韩伦理av电影| 欧美人与z0zoxxxx视频| 国产在线精品国自产拍免费| 国产精品麻豆网站| 欧美一区二区三区啪啪| 精品一区二区在线观看| 中文字幕一区二区三区在线播放 | 2023国产一二三区日本精品2022| 日韩高清一区二区| 国产精品色哟哟网站| 欧美日韩在线播放一区| 国产精品 欧美精品| 亚洲丶国产丶欧美一区二区三区| 日韩午夜精品电影| 欧美午夜精品免费| 成人黄色免费短视频| 日本强好片久久久久久aaa| 国产精品福利一区| 2023国产精品自拍| 日韩视频在线你懂得| 91久久香蕉国产日韩欧美9色| 久久国产麻豆精品| 午夜精品免费在线观看| 一区二区三区免费| 国产精品电影院| 日韩一区日韩二区| 亚洲品质自拍视频| 中文字幕视频一区二区三区久| 日韩精品一区二区三区在线观看 | 麻豆精品一区二区综合av| 亚洲综合自拍偷拍| 亚洲影视在线观看| 亚洲福利视频导航| 日本欧美一区二区三区乱码| 亚洲福利电影网| 久久99久久久欧美国产| 国产一区二区免费看| 国产精品小仙女| 91久久精品一区二区三区| 欧美日韩在线三区| 日韩精品一区二区三区老鸭窝| 久久日韩粉嫩一区二区三区| 国产精品久久久久久久久免费桃花 | 日韩欧美国产三级电影视频| 亚洲女同女同女同女同女同69| 国产色91在线| 亚洲国产精品久久不卡毛片| 人人爽香蕉精品| 日本韩国欧美三级| 精品国产乱码久久久久久免费| 自拍偷拍国产精品| 麻豆国产精品777777在线| 欧美在线观看18| 国产精品国产三级国产aⅴ中文| 免费观看91视频大全| 欧美疯狂做受xxxx富婆| 中文字幕 久热精品 视频在线| 日韩激情一二三区| 欧美年轻男男videosbes| 亚洲色大成网站www久久九九| 国精产品一区一区三区mba桃花| 777午夜精品视频在线播放| 亚洲欧洲制服丝袜| 欧美日韩中文国产| 亚洲一区二区三区在线| 欧洲一区二区三区在线| 一级做a爱片久久| 欧美又粗又大又爽| 日本免费在线视频不卡一不卡二| 欧美久久一二三四区| 日日噜噜夜夜狠狠视频欧美人 | 色av成人天堂桃色av| 亚洲国产sm捆绑调教视频| 91.xcao| 精品一区二区精品| 亚洲欧洲综合另类| 欧美一区二区三区男人的天堂| 毛片基地黄久久久久久天堂| 国产亚洲污的网站| 欧美日韩专区在线|