如何从嵌套的Oracle过程检索值?

| 我有一个棘手的Oracle问题。我正在尝试选择一组数据,我们将其称为项目。对于每个项目,我想调用另一个过程并返回一个库存项目。我不确定如何执行两项操作。 如何从嵌套过程中检索值? 如何以SYS_REFCURSOR的形式返回这些检索到的值? 我在这里的尝试是将来自spSelect_Inv_Search的结果放入称为ITEMS_TABLE的嵌套表中。这是行不通的。 下面的代码
PROCEDURE SPSELECT_ITEM (IO_CURSOR OUT SYS_REFCURSOR) 
AS   
  MY_CURSOR SYS_REFCURSOR;
  TYPE ITEM_TYPE IS TABLE OF ITEMS.ITEM_NO%TYPE;
  ITEM_TABLE ITEM_TYPE := ITEM_TYPE();

  CURSOR ITEMS_CURSOR IS
      SELECT ITEM_NO 
      FROM ITEMS;

  V_COUNTER INTEGER := 0;
BEGIN
  FOR ITEM_REC IN ITEM_CURSOR LOOP
    V_COUNTER := V_COUNTER + 1;
    ITEM_TABLE.EXTEND;
    ITEM_TABLE(V_COUNTER) := spSelect_Inv_Search(ITEM_REC.ITEM_NO, MY_CURSOR);
  END LOOP;
END SPSELECT_ITEMS;
任何帮助表示赞赏,谢谢。     
已邀请:
您似乎想将未知数量的
SYS_REFCURSOR
结果集合并为一个大集合。如果您知道从
spSelect_Inv_Search
返回的游标的结构,则可以使用中间管道函数来实现。
create package p as
    type tmp_rec_type is record (owner all_objects.owner%type,
        object_type all_objects.object_type%type,
        objects number);
    type tmp_rec_table is table of tmp_rec_type;

    procedure proc1(p_owner in varchar2, p_cursor out sys_refcursor);
    function func2 return tmp_rec_table pipelined;
    procedure proc3(p_cursor out sys_refcursor);
end;
/
可以在此处定义类型,它们不必处于SQL级别,因为您无需在包外引用它们。
create package body p as
    procedure proc1(p_owner in varchar2, p_cursor out sys_refcursor) as
    begin
        open p_cursor for select owner, object_type, count(*)
            from all_objects
            where owner = p_owner
            group by owner, object_type;
    end;

    function func2 return tmp_rec_table pipelined as
        cursor c1 is select distinct owner
            from all_tables where owner in (\'SYS\',\'SYSTEM\');
        tmp_cursor sys_refcursor;
        tmp_rec tmp_rec_type;
    begin
        for r1 in c1 loop
            proc1(r1.owner, tmp_cursor);
            loop
                fetch tmp_cursor into tmp_rec;
                exit when tmp_cursor%notfound;
                pipe row(tmp_rec);
            end loop;
        end loop;
    end;

    procedure proc3(p_cursor out sys_refcursor) as
    begin
        open p_cursor for select * from table(func2);
    end;
end p;
/
然后执行(尽管中间阶段使用的是哪种类型,也可以在包外部执行),可以在SQL * Plus或SQL Developer中进行测试:
var rc refcursor;
exec p.proc3(:rc);
print rc;
对于我的数据库,它给出:
OWNER                          OBJECT_TYPE         OBJECTS                
------------------------------ ------------------- ---------------------- 
SYSTEM                         VIEW                1                      
SYSTEM                         TABLE               5                      
SYS                            VIEW                1056                   
SYS                            CONSUMER GROUP      2                      
SYS                            PROCEDURE           11                     
SYS                            FUNCTION            56                     
SYS                            SEQUENCE            1                      
SYS                            OPERATOR            6                      
SYS                            EVALUATION CONTEXT  1                      
SYS                            TABLE               13                     
SYS                            WINDOW GROUP        1                      
SYS                            PACKAGE             162                    
SYS                            WINDOW              2                      
SYS                            TYPE                529                    
SYS                            JOB CLASS           1                      
SYS                            SCHEDULE            1     
这显然是非常人为的,因为您可以将其作为单个查询来执行,但是我假设您的内部过程需要做一些更复杂的事情。     
在回答有关如何调用ѭ2的问题时,我需要知道该子程序的签名。您已经将其描述为一个过程,但是您正在尝试将其称为函数。哪有它具有哪些返回值和/或OUT模式参数? 要从上述过程返回打开的REF CURSOR,首先需要在模式级别(使用a8ѭ语句)而不是PL / SQL代码中声明嵌套表类型。然后,在填充嵌套表之后,可以像这样打开游标。
OPEN io_cursor FOR SELECT * FROM TABLE(CAST(item_table AS item_type));
(顺便说一下,我自己将类型的名称从
ITEM_TYPE
更改为
ITEM_TABLE_TYPE
。)     

要回复问题请先登录注册