У меня возникла странная проблема в коде «УЖЕ РАБОТА». Выполняется рабочая процедура pkg_pbrer.p_gen_pbrer_rpt, которая возвращает v_po_report как выходной курсор.ORA-00932 в выборке курсора
Я пытаюсь захватить этот курсор в table_po_report_62, и это работает нормально.
Теперь я столкнулся ошибка
ORA-00932: несовместимые типы данных:. Ожидается, - получил -»в курсоре принести заявления
Для простоты понимания, я опущено ненужные строки кода.
DECLARE
v_po_report SYS_REFCURSOR;
TYPE type_po_report_62 IS RECORD (soc varchar2(1000), pt varchar2(1000), mp varchar2(1000),
blind varchar2(1000), ac varchar2(1000), placebo varchar2(1000));
table_po_report_62 type_po_report_62;
--
--
-- Some working code
--
--
-- Initializing Reference cursor
open v_po_report for 'select 1 from dual';
pkg_pbrer.p_gen_pbrer_rpt (v_user_id,v_report_type,v_report_form_id,v_reg_report_id,v_po_report,v_po_case_list);
LOOP
FETCH v_po_report INTO table_po_report_62;
-- Encountered ORA-00932: inconsistent datatypes: expected - got -
EXIT WHEN v_po_report%NOTFOUND;
insert into pbrer_output62_report (soc, pt, mp, blind, ac, placebo)
values (table_po_report_62.soc, table_po_report_62.pt, table_po_report_62.mp, table_po_report_62.blind, table_po_report_62.ac, table_po_report_62.placebo) ;
END LOOP;
CLOSE v_po_report;
EXCEPTION
WHEN OTHERS THEN
--
--
-- Some working code
--
--
END;
'v_po_report' является ** REFCURSOR * *, который указывает на набор данных ** с одной строкой ** с ** единственным значением столбца 1 **, т.е. ** типом данных ** NUMBER **. Пока вы пытаетесь ввести ** тип записи ** с совершенно другой структурой. –