Re: BUG #17575: row(NULL) IS NULL inconsistent with IS NOT DISTINCT FROM NULL

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: BUG #17575: row(NULL) IS NULL inconsistent with IS NOT DISTINCT FROM NULL
Дата
Msg-id 3914924.1659709419@sss.pgh.pa.us
обсуждение исходный текст
Ответ на BUG #17575: row(NULL) IS NULL inconsistent with IS NOT DISTINCT FROM NULL  (PG Bug reporting form <noreply@postgresql.org>)
Ответы Re: BUG #17575: row(NULL) IS NULL inconsistent with IS NOT DISTINCT FROM NULL  (Алексей Борщёв <aborschev@gmail.com>)
Список pgsql-bugs
PG Bug reporting form <noreply@postgresql.org> writes:
> I noticed strange behavior of ROW(NULL): 
> I expect, that  IS NULL  operator should give the same result as  IS NOT
> DISTINCT FROM NULL
> similarly, IS NOT NULL  operator should give the same result as  IS DISTINCT
> FROM NULL:     

I don't see any particular reason to expect that.  row(NULL)
is a row object containing one null field, which is in fact not
identical to a null composite value.  The SQL spec dictates that
IS NULL should return true for both cases, but that doesn't mean
that no other operator is allowed to distinguish them.  I'd say
that this is a wart of IS NULL rather than desirable behavior
we should copy elsewhere.

> Next point:
> I expected that IS NULL and IS NOT NULL operators must always return
> opposite results, but:

You have not read the SQL standard, then.  It's quite clear
about that.
 
> Can we fix or document this PG issue?

... nor our documentation.  See

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

para beginning "If the expression is row-valued,", near the
bottom of the page.

            regards, tom lane



В списке pgsql-bugs по дате отправления:

Предыдущее
От: 王海洋
Дата:
Сообщение: Re: [External] Re: [PATCH] BUG FIX: inconsistent page found in BRIN_REGULAR_PAGE
Следующее
От: Tom Lane
Дата:
Сообщение: Re: BUG #17570: Unrecognized node type for query with statistics on expressions