From: | Michael Fuhr <mike(at)fuhr(dot)org> |
---|---|
To: | "Matt A(dot)" <survivedsushi(at)yahoo(dot)com> |
Cc: | pgsql-general(at)postgresql(dot)org |
Subject: | Re: Altering functions cast |
Date: | 2005-08-26 20:12:16 |
Message-ID: | 20050826201216.GA18619@winnie.fuhr.org |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
On Fri, Aug 26, 2005 at 12:22:27PM -0700, Matt A. wrote:
> How do I get this to work?
>
> create function nullif_bool(boolean) returns
> bool as ' select nullif(''$1'','''')::bool;' language
> sql;
If an empty string is a possible input then the argument type can't
be boolean because you'll get a syntax error before the function
is called:
CREATE FUNCTION nullif_bool(boolean) RETURNS boolean AS '
SELECT TRUE; -- for testing
' LANGUAGE sql;
SELECT nullif_bool('');
ERROR: invalid input syntax for type boolean: ""
The argument type should probably be text. But then you get a
different error, this time during function creation:
CREATE FUNCTION nullif_bool(text) RETURNS boolean AS '
SELECT nullif($1,'''')::boolean;
' LANGUAGE sql;
ERROR: cannot cast type text to boolean
One possible solution is to use PL/pgSQL instead of SQL and rely
on PL/pgSQL's automatic type conversion of the return value:
CREATE FUNCTION nullif_bool(text) RETURNS boolean AS '
BEGIN
RETURN nullif($1, '''');
END;
' LANGUAGE plpgsql IMMUTABLE STRICT;
SELECT nullif_bool('');
nullif_bool
-------------
(1 row)
SELECT nullif_bool('t');
nullif_bool
-------------
t
(1 row)
SELECT nullif_bool('f');
nullif_bool
-------------
f
(1 row)
Is that what you're looking for?
--
Michael Fuhr
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2005-08-26 20:16:13 | Re: PG 8.0 "CONNECT BY" patch |
Previous Message | Michael Fuhr | 2005-08-26 19:48:30 | Re: PQConnectdb SSL (sslmode): Is this a bug |