Re: Please provide examples of rows from
От | Tom Lane |
---|---|
Тема | Re: Please provide examples of rows from |
Дата | |
Msg-id | 798909.1600562993@sss.pgh.pa.us обсуждение исходный текст |
Ответ на | Re: Please provide examples of rows from (Bruce Momjian <bruce@momjian.us>) |
Ответы |
Re: Please provide examples of rows from
Re: Please provide examples of rows from |
Список | pgsql-docs |
Bruce Momjian <bruce@momjian.us> writes: > test=> \df pg_get_keywords > List of functions > Schema | Name | Result data type | Argument data types | Type > ------------+-----------------+------------------+-----------------------------------------------------------------------------------------------+------ > pg_catalog | pg_get_keywords | SETOF record | OUT word text, OUT catcode "char", OUT barelabel boolean, OUT catdesctext, OUT baredesc text | func > (1 row) > test=> select * from pg_get_keywords() AS f(word text); > --> ERROR: a column definition list is only allowed for functions returning "record" > LINE 1: select * from pg_get_keywords() AS f(word text); Yeah, this error message needs some help. With a function having multiple OUT parameters, the prorettype is indeed "record", but the specific record type is implied by the OUT parameters so you do not need to (and can't) specify it in the query. The point of the AS feature is to allow specifying the concrete record type for record-returning functions that don't have a predefined result record type, like dblink(). I think this error text was written before we had multiple OUT parameters, so it was okay at the time; but now it needs to be more precise. regards, tom lane
В списке pgsql-docs по дате отправления: