加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 16:30:01 所属栏目:百科 来源:网络整理
导读:查找使用R调用Oracle存储过程并返回结果集的示例. 我正在使用RJDBC库,dbGetQuery来调用Sybase procs并将结果指向一个变量,这对于Oracle select stmts也是如此.但是,我没有看到如何从Oracle存储过程(即从sys_refcursor out param)返回Oracle结果集.我找到的从
查找使用R调用Oracle存储过程并返回结果集的示例.

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

在谷歌搜索导致我“dbCallProc – 调用SQL存储过程”听起来很有希望,但我发现它的每一个参考表明它是“尚未实现”.

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

谢谢,
麦克风

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

我不能专门用R来帮助你,但你说你在调用使用OUT params作为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处理它).

希望有所帮助.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读