我有一个存储过程,其下面的基本布局返回一个sys_refcursor作为结果集。 (从技术上讲,它重新发布了四个,但为了清楚起见,我只说一个)。结果集是从临时表中选择的。
procedure aProcedure
( C1 in out sys_refcursor
) is
begin
--populate Temp_Table here with a stored proc call;
OPEN C1 FOR
SELECT Cols
FROM TEMP_TABLE;
我需要使用不同的存储过程将C1中的结果集插入到永久表中。这是可行的还是我需要重新构建结果集?
我已经能够找到有关使用oracle之外的游标和结果集的信息,但不能在其内部使用它们。
我知道从第一个存储过程执行插入可能是有意义的,但这不是我真正需要它发生的方式。永久保存结果集是一项可选要求。
感谢您提供任何有用的信息。
答案 0 :(得分:16)
假设调用者知道aProcedure
正在打开的游标结构,你可以这样做。
declare
l_rc sys_refcursor;
l_rec temp_table%rowtype;
begin
aProcedure( l_rc );
loop
fetch l_rc
into l_rec;
exit when l_rc%notfound;
dbms_output.put_line( l_rec.col1 );
end loop;
close l_rc;
end;
/
如果无法获取记录类型,还可以获取许多其他标量局部变量(数字和类型必须与aProcedure
在其{中指定的列数和类型相匹配{1}}列表)。就我而言,我定义了SELECT
以返回两个数字列
aProcedure