ORACLE臨時表—ON COMMIT DELETE ROWS,ON COMMIT PRESERVE ROWS
ORACLE臨時表—ON COMMIT PRESERVE ROWS
臨時表:像普通表一樣,有結構,但是對數據的管理上不一樣,臨時表存儲事務或會話的中間結果集,臨時表中保存的數據只對當前
會話可見,所有會話都看不到其他會話的數據,即使其他會話提交了,也看不到。臨時表不存在併發行爲,因爲他們對於當前會話都是獨立的。
創建臨時表時,ORACLE只創建了表的結構(在數據字典中定義),並沒有初始化內存空間,當某一會話使用臨時表時,ORALCE會從當前用戶的
臨時表空間分配一塊內存空間。也就是說只有向臨時表中插入數據時,纔會給臨時表分配存儲空間。
臨時表分事務級臨時表和會話級臨時表。
事務級臨時表只對當前事務有效,通過語句:ON COMMIT DELETE ROWS 語句指定。
會話級臨時表對當前會話有效,通過語句:ON COMMIT PRESERVE ROWS語句指定。
用法舉例(在SCOTT模式下):
CREATE GLOBAL TEMPORARY TABLE session_temp_tab ON COMMIT PRESERVE ROWS AS SELECT * FROM emp WHERE 1=2;
ON COMMIT PRESERVE ROWS語句指定所創建的臨時表是會話級臨時表,當我們斷開連接或手動執行DELETE或TRUNCATE之前,臨時表中的數據一直存
在,並且只有當前會話可以看到,其他會話看不到。
CREATE GLOBAL TEMPORARY TABLE transaction_temp_tab ON COMMIT DELETE ROWS AS SELECT * FROM emp WHERE 1=2;
ON COMMIT DELETE ROWS語句指定所創建的臨時表是事務級臨時表,當COMMIT或ROLLBACK之前,這些數據一直存在,當事務提交之後,表中數據自動清除。
insert into session_temp_tab select * from emp ;
insert into transaction_temp_tab select * from emp ;
SQL> select count(*) from session_temp_tab ;
COUNT(*)
----------
14
SQL> select count(*) from transaction_temp_tab ;
COUNT(*)
----------
14
SQL> commit;
Commit complete
SQL> select count(*) from session_temp_tab ;
COUNT(*)
----------
14
SQL> select count(*) from transaction_temp_tab ;
COUNT(*)
----------
0
當COMMIT之後事務級臨時表中的數據自動清除,所以再次查詢的時候得到結果爲0 ;
SQL> disconnect ;
Not logged on
SQL> connect scott/tiger ;
Connected to Oracle Database 11g Enterprise Edition Release 11.1.0.6.0
Connected as scott
SQL> select count(*) from transaction_temp_tab ;
COUNT(*)
----------
0
SQL> select count(*) from session_temp_tab ;
COUNT(*)
----------
0
當斷開之後重新連接之後,會話級臨時表中的數據也被自動刪除了。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.