Re: Please provide examples of rows from - Mailing list pgsql-docs

From Tom Lane
Subject Re: Please provide examples of rows from
Date
Msg-id 798909.1600562993@sss.pgh.pa.us
Whole thread Raw
In response to Re: Please provide examples of rows from  (Bruce Momjian <bruce@momjian.us>)
Responses Re: Please provide examples of rows from
Re: Please provide examples of rows from
List 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 by date:

Previous
From: Bruce Momjian
Date:
Subject: Re: Please provide examples of rows from
Next
From: Bruce Momjian
Date:
Subject: Re: Please provide examples of rows from