ORACLE臨時表—ON COMMIT PRESERVE ROWS


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM