Re: PL/pgSQL: How to return two columns and multiple rows

From: "David G(dot) Johnston" <david(dot)g(dot)johnston(at)gmail(dot)com>
To: Sven Geggus <lists(at)fuchsschwanzdomain(dot)de>
Cc: "pgsql-general(at)postgresql(dot)org" <pgsql-general(at)postgresql(dot)org>
Subject: Re: PL/pgSQL: How to return two columns and multiple rows
Date: 2015-06-18 12:45:10
Message-ID: CAKFQuwZWOUW94kZDHm9rcY==mq00+Zkzg1BvTShZBDh-gaOTMw@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

On Thursday, June 18, 2015, Sven Geggus <lists(at)fuchsschwanzdomain(dot)de> wrote:

> Hello,
>
> I supose this is simple, but I did not find a solution in the
> documentation.
>
> I would like to be able to do something like this:
>
> select myfunc('foo','bar');
> or
> select myfunc(foo, bar) from foobartable;
> or even
> select myfunc(foo, bar), 'baz' as baz from foobartable;
>
> Which should return something like this:
> foo | bar
> ------+------
> foo1 | bar1
> foo2 | bar2
> foo3 | bar3
> foo4 | bar4
> (4 rows)
>
> So the output should be at least two columns and (usually) more than one
> row.
>
> What I currently have is the following, which is mostly it. Unfortunately
> it gives me only one column (I really need two) and I would have to create
> a
> custom type:
>
> CREATE TYPE t_foobar AS (foo text, bar text);
>
> CREATE or REPLACE FUNCTION myfunc(foo text, bar text)
> returns SETOF t_foobar as $$
> BEGIN
> FOR i IN 1..4 LOOP
> RETURN NEXT (foo || i::text, bar || i::text);
> END LOOP;
> RETURN;
> END;
> $$ language 'plpgsql';
>
> mydb=> select myfunc('foo','bar');
> myfunc
> -------------
> (foo1,bar1)
> (foo2,bar2)
> (foo3,bar3)
> (foo4,bar4)
> (4 rows)
>

Look at the "returns table (col1 type, col2 type)" form.

David J.

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Chris Travers 2015-06-18 12:50:57 Re: PL/pgSQL: How to return two columns and multiple rows
Previous Message Pavel Stehule 2015-06-18 12:44:55 Re: PL/pgSQL: How to return two columns and multiple rows