Re: 9.17.5. Row-wise Comparison

From: TJ O'Donnell <tjo(at)acm(dot)org>
To: pgsql-sql(at)postgresql(dot)org
Subject: Re: 9.17.5. Row-wise Comparison
Date: 2005-04-07 13:44:22
Message-ID: 42553936.2010108@acm.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: 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(at)acm(dot)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

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Ragnar Hafstað 2005-04-07 15:51:54 Re: 9.17.5. Row-wise Comparison
Previous Message Richard Huxton 2005-04-07 12:37:47 Re: Table PARTITION