一、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,重新登录记录也不存在 。
由于编译时临时表还没有生成,直接insert会报错表不存在,所以insert也要用动态sql执行
- create or replace procedure pro as
- str_sql varchar2(100);
- begin
- -- 创建临时表
- str_sql := 'create global temporary table temp_table (
- col1 varchar2(10),
- col2 number
- ) on commit preserve rows';
- execute immediate str_sql;
- -- 使用临时表
- str_sql := 'insert into temp_table(col1, col2) values(''a'', 1)';
- execute immediate str_sql;
- -- 删除临时表
- str_sql := 'drop table temp_table';
- execute immediate str_sql;
- 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;