From: | "Dan Langille" <dan(at)langille(dot)org> |
---|---|
To: | Stephan Szabo <sszabo(at)megazone(dot)bigpanda(dot)com> |
Cc: | <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: Getting the return type right for SETOF |
Date: | 2003-08-31 01:16:26 |
Message-ID: | 3F51142A.19665.30EA4C00@localhost |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
On 30 Aug 2003 at 13:59, Stephan Szabo wrote:
> On Sat, 30 Aug 2003, Dan Langille wrote:
>
> > Hi folks,
> >
> > I'm playing with SETOF on functions. But I can't get the return type
> > correct. What have I missed? A cast?
> >
> > CREATE OR REPLACE FUNCTION elementGet (text) RETURNS SETOF
> > element_type AS '
> >
> > select 1,
> > \'test\',
> > \'F\'
> > \'A\',
> > FALSE,
> > FALSE
> > '
> > LANGUAGE sql stable;
> > ERROR: function declared to return element_type returns "unknown"
> > instead of text at column 2
>
> I think you'll need to explicitly make the three text columns text rather
> than just a plain literal (so ''test''::text for example)
Right you are! Here is the real function:
CREATE OR REPLACE FUNCTION elementGet (text) RETURNS SETOF
element_type AS '
select id,
name::text,
directory_file_flag::text,
status::text,
case when IsPort( Pathname_ID($1)) IS NULL THEN FALSE ELSE
TRUE END,
case when IsCategory(Pathname_ID($1)) IS NULL THEN FALSE ELSE
TRUE END
FROM element
WHERE id = PathName_ID($1);
'
LANGUAGE sql stable;
select * from elementGet('ports/security/logcheck');
id | name | type | status | iscategory | isport
-------+----------+------+--------+------------+--------
37342 | logcheck | D | A | t | f
And it's fast too:
explain analyse select * from elementGet('ports/security/logcheck');
QUERY PLAN
----------------------------------------------------------------------
-----------------------------------------
Function Scan on elementget (cost=0.00..12.50 rows=1000 width=102)
(actual time=64.28..64.28 rows=1 loops=1)
Total runtime: 64.35 msec
Thank you.
--
Dan Langille : http://www.langille.org/
From | Date | Subject | |
---|---|---|---|
Next Message | Jan Wieck | 2003-09-01 02:12:02 | Re: BEFORE UPDATE Triggers |
Previous Message | Tom Lane | 2003-08-30 21:56:27 | Re: BEFORE UPDATE Triggers |