寻找使用 R 调用 Oracle 存储过程并返回结果集的示例。
我使用 RJDBC 库 dbGetQuery 来调用 Sybase procs 并将结果指向变量,这对于 Oracle select stmts 的工作原理相同。但是,我不知道如何让它从 Oracle 存储过程(即从 sys_refcursor out 参数)返回 Oracle 结果集。我找到的从 Oracle 检索数据的唯一示例涉及“从表中选择列”。
在谷歌搜索让我找到了“dbCallProc – 调用 SQL 存储过程“这听起来很有希望,但我发现的每一个参考文献都表明它是”尚未实现。"
有使用 proc 的指针或示例吗?不胜感激。不知道为什么Oracle总是要在检索结果集方面遇到这样的挑战......
谢谢,
麦克风
UPDATE:我举一个简单地称为 Oracle 存储过程的示例。 RJDBC 目前不支持 Oracle 过程吗?
我无法专门帮助您使用 R,但您说您在调用使用 OUT 参数作为 sys_refcursors 的 Oracle 过程时遇到问题。您还指出此功能可能尚未实现。但是,您确实说您可以“从表中选择列”。
因此,我建议将过程更改为管道函数调用,然后执行简单的选择以从 Oracle 获取数据。一个小例子:
CREATE OR REPLACE package pkg1 as
type t_my_rec is record
(
num my_table.num%type,
val my_table.val%type
);
type t_my_tab is table of t_my_rec;
function get_recs(i_rownum in number)
return t_my_tab
pipelined;
END pkg1;
包体:
create or replace package body pkg1 as
function get_recs(i_rownum in number)
return t_my_tab
pipelined
IS
my_rec t_my_rec;
begin
-- get some data
-- implement same business logic as in procedure
for my_rec in (select num, val from my_table where rownum <= i_rownum)
loop
pipe row(my_rec);
end loop;
return;
end get_recs;
end pkg1;
Usage:
select * from table(pkg1.get_recs(3));
Or:
select num, val from table(pkg1.get_recs(3));
这将返回 3 行数据,就像过程返回相同的数据一样。只有这样你才能从 select 语句中获取它(你似乎可以从 R 中处理它)。
希望有帮助。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)