I have to write an Oracle procedure which should invoke an Oracle function returning REF_CURSOR. The function is declared like that
FUNCTION "IMPACTNET"."TF_CONVERTPARA" (PARASTRING IN NVARCHAR2) RETURN SYS_REFCURSOR
AS
c SYS_REFCURSOR;
BEGIN
OPEN c FOR
SELECT SUBSTR(element, 1, INSTR(element, '|') - 1) as key,
SUBSTR(element, INSTR(element, '|') + 1, 99999) as val
FROM (
SELECT REGEXP_SUBSTR(PARASTRING, '[^;]+', 1, LEVEL) element
FROM dual
CONNECT BY LEVEL < LENGTH(REGEXP_REPLACE(PARASTRING, '[^;]+')) + 1
);
RETURN c;
END;
Can you tell me what I need to write in order to invoke the function from within my procedure? I’d like to insert all the returned values (shaped a table with two columns) into a rational table.
Thank you in advance!
Something along the lines of this should work (obviously, I’m guessing about table names and column names and the exact logic that you’re trying to implement)
As Ollie points out, it would be more efficient to do a
BULK COLLECTand aFORALL. If you’re just dealing with a few thousand rows (since your function is just parsing the data in a delimited string, I’m assuming you expect relatively few rows to be returned), the performance difference is probably minimal. But if you’re processing more data, the difference can be quite noticeable. Depending on the Oracle version and your specific requirements, you may be able to simplify theINSERTstatement in theFORALLto insert a record rather than listing each column from the record individually.