Re: XML column causes record to be both NULL and NOT NULL - Mailing list pgsql-bugs

From Tom Lane
Subject Re: XML column causes record to be both NULL and NOT NULL
Date
Msg-id 881845.1688497164@sss.pgh.pa.us
Whole thread Raw
In response to XML column causes record to be both NULL and NOT NULL  (Wilm Hoyer <W.Hoyer@dental-vision.de>)
Responses AW: XML column causes record to be both NULL and NOT NULL
List pgsql-bugs
Wilm Hoyer <W.Hoyer@dental-vision.de> writes:
> i found a strange behavior and hope it's not a pilot error.

Well, it is strange, but it's acting per SQL spec.
As stated at [1]:

    If the expression is row-valued, then IS NULL is true when the row
    expression itself is null or when all the row's fields are null, while
    IS NOT NULL is true when the row expression itself is non-null and all
    the row's fields are non-null. Because of this behavior, IS NULL and
    IS NOT NULL do not always return inverse results for row-valued
    expressions; in particular, a row-valued expression that contains both
    null and non-null fields will return false for both tests.

The fact that the added column is of XML type isn't relevant here;
what's relevant is that it has a null value.

            regards, tom lane

[1] https://www.postgresql.org/docs/current/functions-comparison.html



pgsql-bugs by date:

Previous
From: Wilm Hoyer
Date:
Subject: XML column causes record to be both NULL and NOT NULL
Next
From: Masahiko Sawada
Date:
Subject: Re: BUG #17695: Failed Assert in logical replication snapbuild.