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


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中插入数据

如图:

 

3:查看tmp_session与tmp_transaction中的数据


 

4:commit之后

此时的tmp_transaciton记录已经消失,tmp_session记录未消失

 

 

5:停止会话之后

 

 

 

此时tmp_session与tmp_transaction中的内容都消失

 

由此可以得出结论:

on commit delete rows事务完成,临时表中的数据就会消失。

on commit preserve rows会话结束,临时表中的数据就会消失。

注意:创建了临时表之后,对于临时表的定义是永久的存放在数

据库中的


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM