Re: 9.17.5. Row-wise Comparison

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: 9.17.5. Row-wise Comparison
Дата
Msg-id 13655.1112849262@sss.pgh.pa.us
обсуждение исходный текст
Ответ на 9.17.5. Row-wise Comparison  (TJ O'Donnell <tjo@acm.org>)
Ответы Re: 9.17.5. Row-wise Comparison  (TJ O'Donnell <tjo@acm.org>)
Список pgsql-sql
"TJ O'Donnell" <tjo@acm.org> writes:
> I've been using syntax like
> select a from tbl where (b,c,d) > (1,2,3)
>    to mean
> select a from t where b>1 and b>2 and d>3

> But I see in the manual at:
> http://www.postgresql.org/docs/7.4/interactive/functions-comparisons.html#AEN12735
> that only = and <> operators are supported.  Does this section of the manual
> not properly apply to this query?  Is the manual in error, or am I
> not understanding?

PG's current code acts as you are supposing, but it is broken because it
doesn't follow the SQL spec, and we will change it as soon as someone
gets around to working on it.

The spec says that this syntax implies a column-by-column ordering,
essentially
if (b > 1) then trueelse if (b = 1 and c > 2) then trueelse if (b = 1 and c = 2 and d > 3) then trueelse false

You can find related discussions in the archives from a few months
back.  The spec's semantics correspond exactly to the sort ordering
of a multiple-column btree index, and so there are good reasons why we'd
want to provide that behavior even if it weren't mandated by the spec.
        regards, tom lane


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

Предыдущее
От: TJ O'Donnell
Дата:
Сообщение: 9.17.5. Row-wise Comparison
Следующее
От: "Dinesh Pandey"
Дата:
Сообщение: ar: Command not found.