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

Mik*_*ike 6 oracle stored-procedures r resultset

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

我正在使用RJDBC库,dbGetQuery来调用Sybase procs并将结果指向一个变量,这对于Oracle select stmts也是如此.但是,我没有看到如何从Oracle存储过程(即从sys_refcursor out param)返回Oracle结果集.我找到的从Oracle检索数据的唯一例子涉及"从表中选择列".

在谷歌搜索是导致我" dbCallProc -调用SQL存储过程 ",这听起来非常有前途的,但每一个裁判,我发现这表明它是" 尚未实现. "

使用过程的任何指针或示例?非常感激.不知道为什么Oracle总是必须成为检索结果集的挑战....

谢谢,迈克

更新:我举一个简单称为Oracle存储过程的例子.目前在RJDBC中是否不支持Oracle proc?

tbo*_*one 3

我无法专门帮助您使用 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;
Run Code Online (Sandbox Code Playgroud)

包体:

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;
Run Code Online (Sandbox Code Playgroud)

用法:

select * from table(pkg1.get_recs(3));
Run Code Online (Sandbox Code Playgroud)

或者:

select num, val from table(pkg1.get_recs(3));
Run Code Online (Sandbox Code Playgroud)

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

希望有帮助。