oracle临时表的用法举例

发布时间:2019-09-14编辑:脚本学堂
本文介绍下,oracle中两种临时表的用法,分别是SESSION级临时表、TRANSACTION级临时表,有需要的朋友参考学习下。

本节主要内容:
oracle临时表(SESSION级临时表、TRANSACTION级临时表)。

ORACLE的临时表,可以让用户只能够操作各自的数据中而互不干扰,不用担心会破坏或影响其他SESSION/TRANSACTION的数据。

临时表分为SESSION、TRANSACTION两种,SESSION级的临时表数据在整个SESSION都存在,直到结束此次SESSION;
而TRANSACTION级的临时表数据在TRANACTION结束后消失,即COMMIT/ROLLBACK或结束SESSION都会清除TRANACTION临时表数据。

两种临时表的语法:
 

create global temporary table 临时表名 on commit preserve|delete rows
用preserve时为SESSION级的临时表,用delete则为TRANSACTION级的临时表。

一、SESSION级临时表

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时自动清除记录

二、TRANSACTION级临时表

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,重新登录记录也不存在。