Re: XML column causes record to be both NULL and NOT NULL

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: XML column causes record to be both NULL and NOT NULL
Дата
Msg-id 881845.1688497164@sss.pgh.pa.us
обсуждение исходный текст
Ответ на XML column causes record to be both NULL and NOT NULL  (Wilm Hoyer <W.Hoyer@dental-vision.de>)
Ответы AW: XML column causes record to be both NULL and NOT NULL  (Wilm Hoyer <W.Hoyer@dental-vision.de>)
Список 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 по дате отправления:

Предыдущее
От: Wilm Hoyer
Дата:
Сообщение: XML column causes record to be both NULL and NOT NULL
Следующее
От: Masahiko Sawada
Дата:
Сообщение: Re: BUG #17695: Failed Assert in logical replication snapbuild.