dbms_sql.to_cursor_number - 获取SYS_REFCURSOR的无效游标错误

时间:2012-05-14 04:34:38

标签: oracle cursor sys-refcursor

我有以下代码用于创建表和视图。

create table test_company
(
    comp_id number
    , comp_name varchar2(500)
)
;
insert into test_company values(1, 'CompanyA');
insert into test_company values(2, 'CompanyB');
insert into test_company values(3, 'CompanyC');
create or replace view test_company_view as select * from test_company;

我的游标测试有以下代码。但dbms_sql.to_cursor_number收到错误ORA-01001: invalid cursor

set serveroutput on;
declare
    reader test_company_view%ROWTYPE;
    datacursor SYS_REFCURSOR;
    v_cursor_id number;
begin
    open datacursor for select * from test_company_view;
    v_cursor_id := dbms_sql.to_cursor_number(datacursor); -- ERROR: invalid cursor
    loop fetch datacursor into reader;
        exit when datacursor%NOTFOUND;
        dbms_output.put_line(reader.comp_id);
    end loop;
    close datacursor;
end;

我做错了什么?谢谢你的帮助!

我尝试了strongly-typed REF CURSORweakly-typed REF CURSOR,但他们遇到了同样的错误。

1 个答案:

答案 0 :(得分:3)

来自documentation

  

将REF CURSOR变量转换为SQL游标号后,本机动态SQL操作无法访问它。

引发错误的dbms_sql.to_cursor_number不是fetch datacursor into reader,因为datacursor无法再访问,因此会{{1}}。