CREATE OR REPLACE PACKAGE pkg_test
AS
   TYPE myrctype IS REF CURSOR;   PROCEDURE get (p_id NUMBER, p_rc OUT myrctype);
END pkg_test;
/CREATE OR REPLACE PACKAGE BODY pkg_test
AS
   PROCEDURE get (p_id NUMBER, p_rc OUT myrctype)
   IS
      sqlstr   VARCHAR2 (500);
   BEGIN
      IF p_id = 0 THEN
         OPEN p_rc FOR
            SELECT ID, NAME, sex, address, postcode, birthday
              FROM student;
      ELSE
         sqlstr :=
            'select id,name,sex,address,postcode,birthday
           from student where id=:w_id';
         OPEN p_rc FOR sqlstr USING p_id;
      END IF;
   END get;
END pkg_test;
/

解决方案 »

  1.   

    哦,可能理解错了
    我的意思是存储过程里执行两个存储过程,这两个被执行的存储过程和外层这个存储过程都是带游标输出参数的,内部的存储过程的游标参数返回的结果返回给外层的参储过程的游标参数就是CREATE OR REPLACE PROCEDURE( p_rc OUT myrctype)
    begin 
    procedure1(p_rc1 OUT myrctype);
    procedure1(p_rc2 OUT myrctype);
    end;
    然后p_rc1,p_rc2 的结果返回给p_rc。