Thread: 9.17.5. Row-wise Comparison

9.17.5. Row-wise Comparison

From
TJ O'Donnell
Date:
In tbl with columns a,b,c,d.
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?

TJ


Re: 9.17.5. Row-wise Comparison

From
Tom Lane
Date:
"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


Re: 9.17.5. Row-wise Comparison

From
TJ O'Donnell
Date:
I believe I started the multi-column index thread a
few months back, but now that I have it working so well,
I'm a bit nervous it might break in future.
>     if (b > 1) then true>     else if (b = 1 and c > 2) then true>     else if (b = 1 and c = 2 and d > 3) then true>
   else false
 
Your spec sql snippet is like an OR, isn't it, instead
of an AND as I'm reyling on?

After PG is to spec, will the behaviour I now see change?
Or is just that PG now allows itself the option to test in any order,
not ensuring a sorted result?  As I see it, the results
will be the same according to spec, just not necessarily
in the same order.

Thanks for the info, and for getting my meaning in spite
of the typos in my sql.

TJ



Tom Lane wrote:
> "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 true
>     else if (b = 1 and c > 2) then true
>     else if (b = 1 and c = 2 and d > 3) then true
>     else 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


Re: 9.17.5. Row-wise Comparison

From
Ragnar Hafstað
Date:
On Thu, 2005-04-07 at 06:44 -0700, TJ O'Donnell wrote:
> it might break in future.
> 
>  >     if (b > 1) then true
>  >     else if (b = 1 and c > 2) then true
>  >     else if (b = 1 and c = 2 and d > 3) then true
>  >     else false
> Your spec sql snippet is like an OR, isn't it, instead
> of an AND as I'm reyling on?

not really.

> After PG is to spec, will the behaviour I now see change?

yes

> > "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

if b=2, c=1 and d=1 then the expression (b,c,d) > (1,2,3)
currently evaluates to false, but according to spec,
should evaluate to true.

gnari