Это похоже на функцию, которая возвращает курсор ref;
SQL> create or replace function f_my (par_select in varchar2)
2 return sys_refcursor
3 is
4 l_rc sys_refcursor;
5 begin
6 open l_rc for par_select;
7 return l_rc;
8 end;
9 /
Function created.
Вот что у вас сейчас есть:
SQL> select f_my('select * From dept') as f from dual;
F
--------------------
CURSOR STATEMENT : 1
CURSOR STATEMENT : 1
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
Итак, как избавиться от этих CURSOR STATEMENT : 1
строк?Именно SQLPlus отображает их (какой-то другой инструмент может этого не делать).Но, как вы используете SQLPlus, вот как:
SQL> var v_rc refcursor
SQL> exec :v_rc := f_my('select * from dept')
PL/SQL procedure successfully completed.
SQL> print v_rc
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
SQL>