关于on commit preserve rows与on commit delete rows的测试

原创 Oracle 作者:左右手对决 时间:2015-04-06 11:53:11 9443 0
image.png
image.png
1:先分别建立两张表
sql> CREATE GLOBAL TEMPORARY TABLE tmp_session on commit preserve rows as select from t where 1= 0; —会话结束,临时表中的数据就会消失
sql>CREATE GLOBAL TEMPORARY TABLE tmp_transaction on commit delete rows as select
from t where 1 = 0;— 事务完成,临时表中的数据就会消失
2:分别在tmp_session与tmp_transaction中插入数据
如图:
image.png
image.png
3:查看tmp_session与tmp_transaction中的数据
4:commit之后
image.png
此时的tmp_transaciton记录已经消失,tmp_session记录未消失
5:停止会话之后
此时tmp_session与tmp_transaction中的内容都消失
由此可以得出结论:
on commit delete rows事务完成,临时表中的数据就会消失,
on commit preserve rows会话结束,临时表中的数据就会消失。
注意:创建了临时表之后,对于临时表的定义是永久的存放在数
据库中的