Estoy intentando crear una función en el paquete que devuelve una tabla. Espero llamar a la función una vez en el paquete, pero ser capaz de volver a utilizar sus múltiples veces de datos. Aunque sé que creo tablas temporales en Oracle, esperaba mantener las cosas SECAS.Crear una función de Oracle que devuelva una tabla
Hasta ahora, esto es lo que tengo:
Cabecera:
CREATE OR REPLACE PACKAGE TEST AS
TYPE MEASURE_RECORD IS RECORD (
L4_ID VARCHAR2(50),
L6_ID VARCHAR2(50),
L8_ID VARCHAR2(50),
YEAR NUMBER,
PERIOD NUMBER,
VALUE NUMBER
);
TYPE MEASURE_TABLE IS TABLE OF MEASURE_RECORD;
FUNCTION GET_UPS(
TIMESPAN_IN IN VARCHAR2 DEFAULT 'MONTLHY',
STARTING_DATE_IN DATE,
ENDING_DATE_IN DATE
) RETURN MEASURE_TABLE;
END TEST;
cuerpo:
CREATE OR REPLACE PACKAGE BODY TEST AS
FUNCTION GET_UPS (
TIMESPAN_IN IN VARCHAR2 DEFAULT 'MONTLHY',
STARTING_DATE_IN DATE,
ENDING_DATE_IN DATE
) RETURN MEASURE_TABLE IS
T MEASURE_TABLE;
BEGIN
SELECT ...
INTO T
FROM ...
;
RETURN T;
END GET_UPS;
END TEST;
La cabecera compila, el cuerpo no. Un mensaje de error es "valores insuficientes", lo que probablemente significa que debería seleccionar MEASURE_RECORD, en lugar de MEASURE_TABLE.
¿Qué me estoy perdiendo?
Supongo que utilizar un cursor requerirá más recursos (es decir, más lento) que usar una tabla temporal. ¿Estoy en lo correcto? Necesito agrupar los resultados de esta función. ¿Eso altera tu recomendación? – craig
Respecto al cursor, sí, creo que no son muy buenos para el rendimiento, por lo que probablemente sería más rápido hacer un BULK COLLECT como Tony mencionó, y luego iterar sobre el conjunto. Dependerá de la cantidad de filas con las que esté trabajando y otras consideraciones de rendimiento. En cuanto a la agrupación de los resultados, no estoy seguro, pero parece probable que una tabla temporal sea más eficiente que una función canalizada en cualquier caso. Sugeriría más investigación (o mejor aún, experimentando). Haría la pregunta en http://asktom.oracle.com. –
Explique abajo. –