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 
當斷開之後重新連接之後,會話級臨時表中的數據也被自動刪除了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章