ORACLE臨時表—ON COMMIT PRESERVE ROWS
臨時表:像普通表一樣,有結構,但是對數據的管理上不一樣,臨時表存儲事務或會話的中間結果集,臨時表中保存的數據只對當前
會話可見,所有會話都看不到其他會話的數據,即使其他會話提交了,也看不到。臨時表不存在並發行為,因為他們對於當前會話都是獨立的。 www.2cto.com
創建臨時表時,ORACLE只創建了表的結構(在數據字典中定義),並沒有初始化內存空間,當某一會話使用臨時表時,ORALCE會從當前用戶的
臨時表空間分配一塊內存空間。也就是說只有向臨時表中插入數據時,才會給臨時表分配存儲空間。
臨時表分事務級臨時表和會話級臨時表。
事務級臨時表只對當前事務有效,通過語句:ON COMMIT DELETE ROWS 語句指定。
會話級臨時表對當前會話有效,通過語句:ON COMMIT PRESERVE ROWS語句指定。
www.2cto.com
用法舉例(在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之前,這些數據一直存在,當事務提交之后,表中數據自動清除。
www.2cto.com
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
www.2cto.com
當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
當斷開之后重新連接之后,會話級臨時表中的數據也被自動刪除了。