[Pgsql-ayuda] Crear funcion.

Alvaro Herrera alvherre@dcc.uchile.cl
Thu, 29 May 2003 22:07:08 -0400


On Thu, May 29, 2003 at 06:44:33PM -0400, Leonardo Boet Sánchez wrote:

> create function test1() returns test1
> as 'select frase from frases'
> languaje 'sql' ;
> 
> Me da el siguiente error Type test1 does not exist
> 
> de la siguiente forma: 
> 
> create function test1() returns setof test1
> as 'select frase from frases'
> languaje 'sql' ;

test1 debe ser un tipo  que exista.  Si quieres retornar algo que en
tiempo de creacion no existe como tipo (o crearlo en demanda), usa SETOF
RECORD, y llamas al SELECT con la definición del tipo.  Mira la
documentación sobre SETOF.  No es trivial, pero no es ciencia de
cohetes.

http://developer.postgresql.org/docs/postgres/xfunc-sql.html

Ojo, que para cada tabla existe un tipo del mismo nombre.  Seguramente
tu ejemplo funcionaria asi:

create function test1() returns setof frases as 
'select frase from frases' language sql;

select * from test1();

-- 
Alvaro Herrera (<alvherre[a]dcc.uchile.cl>)
Voy a acabar con todos los humanos / con los humanos yo acabaré
voy a acabar con todos / con todos los humanos acabaré (Bender)