1

我有一个关于从弱类型游标中获取结果的快速问题,想知道以前是否有人遇到过这个问题?

我的设置如下;

内部功能;

create or replace FUNCTION A_CURSOR_TEST_INNER
(
  varCursor OUT SYS_REFCURSOR
)
RETURN NUMBER
AS
  varStatus NUMBER;
BEGIN
  OPEN varCursor  FOR
  SELECT docid
  FROM DOCUMENT_TABLE;

  RETURN 0;
END;

调用函数;

create or replace FUNCTION A_CURSOR_TEST_OUTER
(
  varCursor  OUT SYS_REFCURSOR
)
RETURN NUMBER
AS
  varStatus NUMBER;
BEGIN
  varStatus := A_CURSOR_TEST_INNER(varCursor  => varCursor);
  RETURN 0;
END;

测试线束代码;

DECLARE
  varCursor  SYS_REFCURSOR;
  v_Return NUMBER;
BEGIN
  v_Return := A_CURSOR_TEST_OUTER(varCursor  => varCursor);
    DECLARE
        docid_ NUMBER;
    BEGIN
        IF(varCursor %ISOPEN) THEN
            LOOP
                FETCH varCursor  INTO docid_ ;
                EXIT WHEN varCursor %NOTFOUND;
                DBMS_OUTPUT.PUT_LINE(' docid_:' || docid_ );
            END LOOP;
            CLOSE varCursor ;
        END IF;
    END;
END;

如果我运行我的测试工具代码,我得到的错误是;

ORA-06504: PL/SQL: 结果集变量或查询的返回类型不匹配

我不确定是什么导致了这种情况发生。该错误发生在我的测试代码中,但我之前已经使用了数百次完全相同的方法并且没有遇到这个问题。现在唯一的区别是,光标通过两个函数而不是一个函数传递回来。

有谁知道这里可能出现什么问题?我已经用谷歌搜索了它,我能找到的只是强烈键入光标的建议,不幸的是,这对我来说不是一个选择。

感谢任何人都可以提供的任何帮助,干杯。

4

1 回答 1

2

我可以复制您的问题,对我来说这似乎是一个 Oracle 错误。通过谷歌搜索错误,我在 OraFAQ 上发现了对同一问题的讨论

于 2008-11-28T12:18:10.283 回答