Oracle存储过程中临时表的使用技巧

Posted 独具匠心

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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,重新登录记录也不存在 。

以上是关于Oracle存储过程中临时表的使用技巧的主要内容,如果未能解决你的问题,请参考以下文章

Oracle存储过程中临时表的使用技巧

Oracle 存储过程的全局临时表的替代方法

Oracle中如何在储过程中使用临时表

oracle 怎么在存储过程中创建一个临时表,在里面插入数据,再查找这个临时表的所有数据,最后drop这个表。

oracle 怎么在存储过程中创建一个临时表,在里面插入数据,再查找这个临时表的所有数据,最后drop这个表。

Oracle 中临时表的替代方案