Thread: Find out if a parameter/return field is NULLABLE using Describe

Find out if a parameter/return field is NULLABLE using Describe

From
Richard Jones
Date:
It doesn't seem to be possible to find out if a parameter or result
field is nullable using the Describe protocol.

For example if I have this table and statement:
 create table employees (   id serial not null primary key,   name text not null,   email text
 <-- this field );
 
 insert into employees (name, email) values ($1, $2);

Then the only information I get back about $2 is that it's a TEXT (OID
= 25), when clearly $1 and $2 are different in that one is nullable
and the other isn't.

Similarly,
 select name, email from employees;

This time I get more information about the types, including a modifier
and length, but I can't see whether that lets me find out that one
could be NULL and the other can never be.

So is this possible?

Rich.

-- 
Richard Jones, CTO Merjis Ltd.
Merjis - web marketing and technology - http://merjis.com
Team Notepad - intranets and extranets for business - http://team-notepad.com


Re: Find out if a parameter/return field is NULLABLE using Describe

From
Tom Lane
Date:
Richard Jones <rich@annexia.org> writes:
> It doesn't seem to be possible to find out if a parameter or result
> field is nullable using the Describe protocol.

This isn't something that the backend tracks at all, so changing the
wire protocol would be the least of your problems in making it happen...
        regards, tom lane


Re: Find out if a parameter/return field is NULLABLE

From
Kris Jurka
Date:

On Mon, 30 Jan 2006, Tom Lane wrote:

> Richard Jones <rich@annexia.org> writes:
>> It doesn't seem to be possible to find out if a parameter or result
>> field is nullable using the Describe protocol.
>
> This isn't something that the backend tracks at all, so changing the
> wire protocol would be the least of your problems in making it happen...
>

Well, the protocol does attempt to return the resulting columns' source 
table and column number which may then be used to determine the 
nullability of the field.  This won't work in all cases, but for the 
simple select example given, it will.

Kris Jurka