gpt4 book ai didi

oracle - 在 R 中调用 Oracle 存储过程 - 如何获取结果集?

转载 作者:行者123 更新时间:2023-12-04 15:36:38 25 4
gpt4 key购买 nike

寻找使用 R 调用 Oracle 存储过程并返回结果集的示例。

我正在使用 RJDBC 库 dbGetQuery 来调用 Sybase procs 并将结果指向一个变量,这对于 Oracle select stmts 也是一样的。但是,我不知道如何让它从 Oracle 存储过程(即,从 sys_refcursor out 参数)返回 Oracle 结果集。我发现的从 Oracle 检索数据的唯一示例涉及“从表中选择列”。

在 google 中搜索让我找到了“dbCallProc – 调用 SQL 存储过程”,这听起来很有希望,但我发现的每个引用都表明它“尚未实现”。

使用 procs 的任何指针或示例?不胜感激。不知道为什么Oracle检索结果集总是要这么挑战....

谢谢,
麦克风

更新 :我会举一个简单地调用 Oracle 存储过程的例子。 RJDBC 目前是否根本不支持 Oracle procs?

最佳答案

我无法专门为您提供 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;

用法:
select * from table(pkg1.get_recs(3));

或者:
select num, val from table(pkg1.get_recs(3));

这将返回 3 行数据,就像过程将返回相同的数据一样。只有这样,您才能从 select 语句中获取它(您似乎可以从 R 中处理)。

希望有帮助。

关于oracle - 在 R 中调用 Oracle 存储过程 - 如何获取结果集?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7562665/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com