如何从从 plsql 函数 ORACLE 返回的游标中进行选择

Posted

技术标签:

【中文标题】如何从从 plsql 函数 ORACLE 返回的游标中进行选择【英文标题】:How to make a select from a cursor that returns from a plsql function ORACLE 【发布时间】:2017-10-05 09:16:46 【问题描述】:

我有一个返回光标的函数我的包是这样的

FUNCTION SEDIRUNTIME (sede varchar2) return SYS_REFCURSOR

此游标返回 x 行只有一个值,例如:

 ROW1 - 34
 ROW2 - 55
 ROW3 - 56  ecc. ecc.

现在我有我这样选择

.. AND field in  (select DBK_ENIN_REPORT.*SEDIRUNTIME*(sede) from dual)

这将模拟一个子句IN,我们可以在运行时知道它的值。

例如,根据位置参数,光标可以给我 22 和 34 而不仅仅是 56 或 78 98 09。

这样我就不能使用错误号 00932 不连贯的数据类型。

解决方案?

【问题讨论】:

另见***.com/questions/18035778/…和***.com/questions/20415107/… 【参考方案1】:

你不能像那样使用CURSOR

但是你可以改变函数来返回一个集合:

CREATE TYPE Numberlist IS TABLE OF NUMBER;
/

CREATE FUNCTION DBK_ENIN_REPORT.SEDIRUNTIME (
  sede varchar2
) return NumberList
IS
  out_numbers NumberList;
BEGIN
  SELECT id
  BULK COLLECT INTO out_numbers
  FROM   your_table;

  RETURN out_numbers;
END;
/

那么你可以这样做:

.. AND field MEMBER OF DBK_ENIN_REPORT.SEDIRUNTIME(sede)

.. AND field IN ( SELECT COLUMN_VALUE FROM TABLE( DBK_ENIN_REPORT.SEDIRUNTIME(sede) ) )

【讨论】:

【参考方案2】:

好吧,我会说你 CAN 去做,但你需要 twist 一点点。你可以看到我是如何做到的,如下所示。我以员工表为例。

创建函数:

CREATE OR REPLACE FUNCTION SEDIRUNTIME (sede VARCHAR2)
   RETURN SYS_REFCURSOR
AS
   cur   SYS_REFCURSOR;
BEGIN
   OPEN cur FOR SELECT employee_id FROM employee;

   RETURN cur;
END;
/

可以在包中作为过程实现的匿名块;

DECLARE
   x       SYS_REFCURSOR;
   y       NUMBER;
   v       VARCHAR2 (100);
   v_sql   VARCHAR2 (200);

   TYPE var_emp IS TABLE OF employee%ROWTYPE
      INDEX BY PLS_INTEGER;

   v_emp   var_emp;
BEGIN
   x := SEDIRUNTIME ('sede');

   LOOP
      FETCH x INTO y;

      v := v || ',' || y;

      EXIT WHEN x%NOTFOUND;
   END LOOP;
   --Created the IN clause list
   v := LTRIM (v, ',');

   v_sql := 'Select * from employee where employee_id in (' || v || ')';

   EXECUTE IMMEDIATE v_sql BULK COLLECT INTO v_emp;

   FOR i IN 1 .. v_emp.COUNT
   LOOP
      DBMS_OUTPUT.put_line ( v_emp (i).employee_id || '--' || v_emp (i).first_name);
   END LOOP;
END;

输出:

SQL> /
1--XXX
2--YYY

PL/SQL procedure successfully completed.

SQL> 

PS:当然,MTO 提供的解决方案会比这个快很多。

【讨论】:

以上是关于如何从从 plsql 函数 ORACLE 返回的游标中进行选择的主要内容,如果未能解决你的问题,请参考以下文章

在一行上返回函数中的多个主键列。 PLSQL、SQL ORACLE 开发

如何在 PLSQL Developer 中测试包含 DML 的 Oracle 函数?

如何在oracle plsql中提取和打印函数外的光标值

Oracle PLSQL 函数调用到第二个函数

oracle /plsql 计算平闰年天数函数

从Oracle PLSQL调用java时如何将参数传递给java