度量快速开发平台-专业、快速的软件定制快开平台
标题:
Oracle存储过程中临时表的使用技巧
[打印本页]
作者:
陈晓龙
时间:
2020-6-17 21:08
标题:
Oracle存储过程中临时表的使用技巧
一、Oracle临时表知识
在Oracle中,临时表分为SESSION、TRANSACTION两种,SESSION级的临时表数据在整个SESSION都存在,直到结束此次SESSION;而 TRANSACTION级的临时表数据在TRANACTION结束后消失,即COMMIT/ROLLBACK或结束SESSION都会清除 TRANACTION临时表数据。
1) 会话级临时表 示例
1创建
create global temporary table temp_tbl(col_a varchar2(30))
on commit preserve rows
2插入数据
insert into temp_tbl values('test session table')
3提交
commit;
4查询
select *from temp_tbl
可以看到数据'test session table'记录还在。
结束SESSION,重新登录,再查询数据select *from temp_tbl,这时候记录已不存在,因为系统在结束SESSION时自动清除记录 。
2) 事务级临时表 示例
1创建
create global temporary table temp_tbl(col_a varchar2(30))
on commit delete rows
2插入数据
insert into temp_tbl values('test transaction table')
3提交
commit ;
4查询
select *from temp_tbl
这时候可以看到刚才插入的记录'test transaction table'已不存在了,因为提交时已经晴空了数据库;同样,如果不提交而直接结束SESSION,重新登录记录也不存在 。
作者:
万望
时间:
2020-6-17 23:39
讲的挺详细,看明白了
作者:
万望
时间:
2020-6-17 23:40
作者:
万望
时间:
2020-6-17 23:40
作者:
万望
时间:
2020-6-17 23:45
作者:
陈晓龙
时间:
2020-6-18 22:20
万望 发表于 2016-8-17 23:45
你表情挺多的
欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://p.delit.cn/)
Powered by Discuz! X3.2