Re: proposal: table functions and plpgsql - Mailing list pgsql-hackers

From Pavel Stehule
Subject Re: proposal: table functions and plpgsql
Date
Msg-id 162867790806011153j3f228e0bo79da6893595bc515@mail.gmail.com
Whole thread Raw
In response to proposal: table functions and plpgsql  ("Pavel Stehule" <pavel.stehule@gmail.com>)
List pgsql-hackers
Hello

After some days I thing, so idea of local types is wrong. Maybe we can
register output types for or SRF functions (maybe only for table
functions), but this mechanism is redundant to explicit custom types.
Local functions types are nice, they allows better compile time check,
but they are unnecessary.

Sample:
CREATE OR REPLACE FUNCTION foo(a integer)
RETURNS TABLE(a integer,  b integer) AS $$
DECLARE r record;
BEGIN FOR i IN 1..a LOOP   r := ROW(i, i+1);   RETURN NEXT r; END LOOP; RETURN;
END;
$$ LANGUAGE plpgsql;

or
-- more in SQL/PSM character
CREATE OR REPLACE FUNCTION foo(a integer)
RETURNS TABLE(a integer, b integer) AS $$
BEGIN RETURN TABLE SELECT i, i+1                              FROM generate_series(1,a) g(i); RETURN;
END;
$$ LANGUAGE plpgsql;

any comments??

Regards
Pavel Stehule
2008/5/21 Pavel Stehule <pavel.stehule@gmail.com>:
> Hello
>
> I am returning back to my patch and older proposal
> http://archives.postgresql.org/pgsql-hackers/2007-02/msg00318.php .
>
> Some work did Neil Conway
> http://archives.postgresql.org/pgsql-hackers/2007-07/msg00501.php and
> he commited half of this patch - RETURN QUERY part.
>
> Problematic part of my patch is implementation. Tom Lane proposal
> implenation RETURNS TABLE only as syntactic sugar for RETURNS SETOF
> RECORD. This is not comaptible with potential implementation, because
> it adds some default variables. My solution was special argmode, so I
> was able don't create default variables for output. My solution wasn't
> best too. It was ugly for current plpgsql where is often used RETURN
> NEXT statement (PSM doesn't know similar statement). I unlike default
> variables - it simply way to variables and column names collision.
>
> I propose following syntax for plpgsql:
>
> CREATE OR REPLACE FUNCTION foo(m integer)
> RETURNS TABLE (a integer, b integer) AS $$
> DECLARE r foo; -- same name as function, this type has local visibility
> BEGIN
>  FOR i IN 1..m LOOP
>    r.a := i; r.b := i + 1;
>    RETURN NEXT r;
>  END LOOP;
>  RETURN;
> END;
> $$ LANGUAGE plpgsql;
>
> In my proposal I don't create any default variables. Result type is
> only virtual - I don't need write it to system directory. I thing it's
> better than using some specific predeclared type as RESULTTYPE OR
> RESULTSET.
>
> What do you thing about?
>
> Regards
> Pavel Stehule
>


pgsql-hackers by date:

Previous
From: "Dawid Kuroczko"
Date:
Subject: Re: Core team statement on replication in PostgreSQL
Next
From: "Pavel Stehule"
Date:
Subject: Re: explain doesn't work with execute using