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会话结束,临时表中的数据就会消失。
注意:创建了临时表之后,对于临时表的定义是永久的存放在数
据库中的