Мне нужно получить refcursor во временную таблицу.Каждый столбец refcursor должен соответствовать соответствующему столбцу таблицы + один ключевой (перечислить) столбец должен быть во временной таблице.Например, refcursor возвращает следующие данные:
'one' 'Monday'
'two' 'Friday'
И данные, которые должны храниться в таблице:
1 'one' 'Monday'
2 'two' 'Friday'
Этот рефкурсор открывается в других функциях.Так что я не знаю, какие столбцы должны быть в наборе результатов.Как я могу реализовать что-то вроде FETCH ALL curs INTO temp_table?
Я написал ниже функцию, но она выдает ошибку для (V_CURS_Rec). *
CREATE OR REPLACE FUNCTION FN_TEST()
RETURNS VOID LANGUAGE plpgsql
AS $$
DECLARE
V_CURS REFCURSOR;
V_CURS_Rec RECORD;
ITER INTEGER;
BEGIN
create temporary table if not exists TMP_TBL
(
INDX INTEGER NOT NULL,
CNAME VARCHAR(20),
CDAY VARCHAR(20),
);
DELETE FROM TMP_TBL;
SELECT * FROM FN_RET_REFCURSOR() INTO V_CURS;
ITER := 1;
LOOP
FETCH V_CURS INTO V_CURS_Rec;
EXIT WHEN NOT FOUND;
INSERT INTO TMP_TBL SELECT ITER, (V_CURS_Rec).*;
ITER := ITER + 1;
END LOOP;
RETURN;
END; $$;