sql >> Base de Datos >  >> RDS >> PostgreSQL

Pasar un ResultSet a una función de Postgresql

Podrías usar un cursor , pero muy poco práctico para calcular un mínimo.

Yo usaría una mesa temporal para ese propósito, y pase el nombre de la tabla para usar en SQL dinámico :

CREATE OR REPLACE FUNCTION f_min_id(_tbl regclass, OUT min_id int) AS 
$func$
BEGIN

EXECUTE 'SELECT min(id) FROM ' || _tbl
INTO min_id;

END  
$func$ LANGUAGE plpgsql;

Llamar:

CREATE TEMP TABLE foo ON COMMIT DROP AS
SELECT id, name
FROM   users
LIMIT  50;

SELECT f_min_id('foo');

Puntos principales

-> demostración de SQLfiddle