From: | "Pavel Stehule" <pavel(dot)stehule(at)gmail(dot)com> |
---|---|
To: | "Michele Petrazzo - Unipex srl" <michele(dot)petrazzo(at)unipex(dot)it> |
Cc: | Pgsql-Sql <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: functions are returns columns |
Date: | 2007-11-09 20:35:20 |
Message-ID: | 162867790711091235i7e77abcch27731d91285949b6@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers pgsql-sql |
On 09/11/2007, Michele Petrazzo - Unipex srl <michele(dot)petrazzo(at)unipex(dot)it> wrote:
> Hi all.
> I want that a function return a table rows (like the doc says at 33.4.4.
> SQL Functions as Table Sources), but I want the a function return only a
> few cols, so the same that I select into the func.
> Modifying the doc example:
>
> CREATE TABLE foo (fooid int, foosubid int, fooname text);
> INSERT INTO foo VALUES (1, 1, 'Joe');
> INSERT INTO foo VALUES (1, 2, 'Ed');
> INSERT INTO foo VALUES (2, 1, 'Mary');
>
> CREATE FUNCTION getfoo(int) RETURNS foo AS $$
> SELECT fooid, foosubid FROM foo WHERE fooid = $1;
> $$ LANGUAGE SQL;
>
> This give me an error:
>
> ERROR: return type mismatch in function declared to return foo
> DETAIL: Final SELECT returns too few columns.
> CONTEXT: SQL function "getfoo"
>
>
CREATE FUNCTION getfoo(int) RETURNS foo AS $$
SELECT fooid, foosubid FROM foo WHERE fooid = $1 LIMIT 1;
$$ LANGUAGE SQL;
or
CREATE FUNCTION getfoo(int) RETURNS SETOF foo AS $$
SELECT fooid, foosubid FROM foo WHERE fooid = $1;
$$ LANGUAGE SQL;
try:
SELECT * FROM getfoo(1);
Regards
Pavel Stehule
> So, how do it?
>
> Thanks,
> Michele
>
> ---------------------------(end of broadcast)---------------------------
> TIP 5: don't forget to increase your free space map settings
>
From | Date | Subject | |
---|---|---|---|
Next Message | Andrew Dunstan | 2007-11-09 20:35:39 | Re: plperl.dll error from create langauge plperl (XP Pro 64 bit) |
Previous Message | Doug Knight | 2007-11-09 20:04:01 | plperl.dll error from create langauge plperl (XP Pro 64 bit) |
From | Date | Subject | |
---|---|---|---|
Next Message | Michele Petrazzo - Unipex srl | 2007-11-10 17:37:51 | Re: functions are returns columns |
Previous Message | Michele Petrazzo - Unipex srl | 2007-11-09 19:46:41 | functions are returns columns |