Oracle存储过程中使用临时表

一、Oracle临时表知识   

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

1) 会话级临时表 示例 

1创建

  1. create global temporary table temp_tbl(col_a varchar2(30))  
  2. on commit preserve rows  

 

 2插入数据

  1. insert into temp_tbl values('test session table')  

 

 3提交

  1. commit;  

 

 4查询

  1. select *from temp_tbl  

 

 可以看到数据'test session table'记录还在。
结束SESSION,重新登录,再查询数据select *from temp_tbl,这时候记录已不存在,因为系统在结束SESSION时自动清除记录 。

2) 事务级临时表 示例 

1创建

  1. create global temporary table temp_tbl(col_a varchar2(30))  
  2. on commit delete rows  

   

 

2插入数据

  1. insert into temp_tbl values('test transaction table')  

   

 

3提交

  1. commit ;  

 

4查询

  1. select *from temp_tbl  

 

 这时候可以看到刚才插入的记录'test transaction table'已不存在了,因为提交时已经清空了数据库;同样,如果不提交而直接结束SESSION,重新登录记录也不存在 。

由于编译时临时表还没有生成,直接insert会报错表不存在,所以insert也要用动态sql执行

  1. create or replace procedure pro as  
  2.   str_sql varchar2(100);  
  3. begin  
  4.   -- 创建临时表  
  5.   str_sql := 'create global temporary table temp_table (  
  6.        col1 varchar2(10),  
  7.        col2 number  
  8.     ) on commit preserve rows';  
  9.   execute immediate str_sql;  
  10.   
  11.   -- 使用临时表  
  12.   str_sql := 'insert into temp_table(col1, col2) values(''a'', 1)';  
  13.   execute immediate str_sql;  
  14.   
  15.   -- 删除临时表  
  16.   str_sql := 'drop table temp_table';  
  17.   execute immediate str_sql;  
  18. end;  

动态sql 传参数方法:

declare
  i_bank_id   varchar2(10) := '15';
  i_bank_name varchar2(100) := 'testyy';
  i_flag      varchar2(1) := '0';
  i_oper_time date := sysdate;
begin
  execute immediate 'insert into sys_bank values(:p1,:p2,:p3,:p4)'
    using i_bank_id, i_bank_name, i_flag, i_oper_time;
  commit;
end;



 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值