Re: Null parm to a function - Mailing list pgsql-sql

From Tom Lane
Subject Re: Null parm to a function
Date
Msg-id 18044.961220761@sss.pgh.pa.us
Whole thread Raw
In response to Null parm to a function  (Gordon Clarke <gordonc@acenet.net.au>)
List pgsql-sql
Gordon Clarke <gordonc@acenet.net.au> writes:
> Now if I try to do the same thing but via my function,
>     SELECT insert_row(1235,null,100);
> I get the following error
>     ERROR:  typeidTypeRelid: Invalid type - oid = 0

> Why wont the function allow me to pass a 'null' parm?

You're running into a longstanding shortcoming of the function-call
interface inside Postgres: there's only one NULL-parameter flag passed
to a function, so if any of the parameters are NULL then they all are
taken to be NULL.  I'm not quite sure why you're seeing that particular
error message, but in any case you'd have gotten a failure from the NOT
NULL constraints on the other two columns.

The only comfort I have to offer is that this will work in 7.1 ---
in fact, your example does work in current development sources.  
That's a result of a major rewrite of the function manager.  There's
no chance of backpatching the fix into 7.0.* or earlier.
        regards, tom lane


pgsql-sql by date:

Previous
From: Gordon Clarke
Date:
Subject: Null parm to a function
Next
From: James Carpenter
Date:
Subject: Determining Array size. (HACK)