Re: 9.17.5. Row-wise Comparison - Mailing list pgsql-sql

From TJ O'Donnell
Subject Re: 9.17.5. Row-wise Comparison
Date
Msg-id 42553936.2010108@acm.org
Whole thread Raw
In response to Re: 9.17.5. Row-wise Comparison  (Tom Lane <tgl@sss.pgh.pa.us>)
Responses Re: 9.17.5. Row-wise Comparison  (Ragnar Hafstað <gnari@simnet.is>)
List pgsql-sql
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


pgsql-sql by date:

Previous
From: Harald Fuchs
Date:
Subject: Re: DROP TYPE without error?
Next
From: Ragnar Hafstað
Date:
Subject: Re: 9.17.5. Row-wise Comparison