Search Postgresql Archives

Re: Altering functions cast

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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

---------------------------(end of broadcast)---------------------------
TIP 1: if posting/reading through Usenet, please send an appropriate
       subscribe-nomail command to majordomo@xxxxxxxxxxxxxx so that your
       message can get through to the mailing list cleanly

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux