I need to create a function to generate a list from a table by a select query. First, I created a package and function to generate a table but I get ERROR.
CREATE OR REPLACE PACKAGE test AS
TYPE date_record IS RECORD(
list_target VARCHAR2(50));
TYPE date_table IS TABLE OF date_record;
FUNCTION get_ups(partition_date_in VARCHAR2)
RETURN date_table
PIPELINED;
END;
CREATE OR REPLACE PACKAGE BODY test AS
FUNCTION get_ups(partition_date_in VARCHAR2)
RETURN date_table
PIPELINED IS
rec date_record;
BEGIN
SELECT ltrim(TO_CHAR(MONTH,'mm-yyyy'),'0') BULK COLLECT AS rec
FROM
(
select add_months (trunc (to_date('09/01/2019','dd/mm/yyyy'), 'MM'), 1*Level -1)
Month FROM Dual
CONNECT BY Level <= MONTHS_BETWEEN(to_date('09/01/2019','dd/mm/yyyy'), to_date('09/02/2019','dd/mm/yyyy')) + 1
order by MONTH
);
-- you would usually have a cursor and a loop here
PIPE ROW (rec);
RETURN;
END get_ups;
END;
When I run
SELECT * FROM table(test.get_ups('09/01/2019'));
Errore SQL [4063] [72000]: ORA-04063: package body "SYS.TEST" contiene errori
Can you please help to solve this issue and generate a list?