oracle 存过 临时表 使用,oracle存储过程中临时表的使用,该怎么处理

当前位置:我的异常网» Oracle管理 » oracle存储过程中临时表的使用,该怎么处理

oracle存储过程中临时表的使用,该怎么处理

www.myexceptions.net  网友分享于:2013-03-27  浏览:420次

oracle存储过程中临时表的使用

我想完成一个存储过程 实现创建临时表 插入数据 查询结果(以游标返回) 删除临时表的操作 代码如下 不知道问题在哪?

貌似在用循环插入数据时就出错了,这里我是要用循环插入数据的,要通过筛选数据 不能直接

CREATE GLOBAL TEMPORARY TABLE TEMP_STUDENTINFO ON COMMIT PRESERVE ROWS as select * from table;

代码如下

create or replace procedure sys_Operation_Select

(

V_CX out SYS_REFCURSOR

)

as

V_SqlString varchar2(2000);

CURSOR cur_opt IS select * from sys_Operation;

begin

V_SqlString:='CREATE GLOBAL TEMPORARY TABLE temp_DomainOperation (

ID VARCHAR2(36),

OperationDomain VARCHAR2(36),

Name varchar2(50),

Father varchar2(36),

URL varchar2(200),

Target varchar2(50),

ICON varchar2(50),

Seq integer,

Memo varchar(50)

) ON COMMIT PRESERVE ROWS';

execute immediate V_SqlString;

FOR v_opt IN cur_opt LOOP

V_SqlString:=' insert into temp_DomainOperation values (v_opt.id,v_opt.operationdomain,v_opt.name,v_opt.father,v_opt.url,v_opt.target,v_opt.Icon,v_opt.seq,v_opt.memo)';

DBMS_OUTPUT.PUT_LINE(V_SqlString);

execute immediate V_SqlString;

END LOOP;

V_SqlString:=' select * from TEMP_DOMAINOPERATION';

open V_CX for V_SqlString;

V_SqlString:='drop table temp_DomainOperation';

execute immediate V_SqlString;

end sys_Operation_Select;

------解决方案--------------------

1、oracle临时表不要这样使用,oracle临时表不同于其它数据库的临时表,如果sqlserver;oracle临时表的特点时数据临时。

2、要使用临时表,事先建立好临时表就行了,并由oracle自己去处理并发就行了,并且每个会话的数据是互不影响的。

3、在万不得已的情况下,尽量不要使用动态SQL,因为其性能比静态SQL低。

--建立临时表

CREATE GLOBAL TEMPORARY TABLE temp_DomainOperation(

ID VARCHAR2(36),

OperationDomain VARCHAR2(36),

Name varchar2(50),

Father varchar2(36),

URL varchar2(200),

Target varchar2(50),

ICON varchar2(50),

Seq integer,

Memo varchar(50)

) ON COMMIT PRESERVE ROWS;

--建立存储过程

CREATE OR REPLACE PROCEDURE sys_Operation_Select(V_CX OUT SYS_REFCURSOR)

AUTHID CURRENT_USER AS

V_SqlString VARCHAR2(2000);

CURSOR cur_opt IS

SELECT * FROM sys_Operation;

BEGIN

FOR v_opt IN cur_opt LOOP

V_SqlString := 'insert into temp_DomainOperation values (:id,:operationdomain,:name,:father,:url,:target,:Icon,:seq,:memo)';

DBMS_OUTPUT.PUT_LINE(V_SqlString);

EXECUTE IMMEDIATE V_SqlString

USING v_opt.id, v_opt.operationdomain, v_opt.name, v_opt.father, v_opt.url, v_opt.target, v_opt.Icon, v_opt.seq, v_opt.memo;

END LOOP;

V_SqlString := ' select * from TEMP_DOMAINOPERATION';

OPEN V_CX FOR V_SqlString;

END sys_Operation_Select;

文章评论

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值