Re: POC, WIP: OR-clause support for indexes - Mailing list pgsql-hackers

From Pavel Borisov
Subject Re: POC, WIP: OR-clause support for indexes
Date
Msg-id CALT9ZEEyivV=CDE=CCf8JwT5dU2epBDmbiRyVg8fO7-m6rud7g@mail.gmail.com
Whole thread Raw
In response to Re: POC, WIP: OR-clause support for indexes  (Andrei Lepikhov <lepihov@gmail.com>)
Responses Re: POC, WIP: OR-clause support for indexes
List pgsql-hackers
Hi, Andrei!

On Mon, 24 Mar 2025 at 14:10, Andrei Lepikhov <lepihov@gmail.com> wrote:
>
> Hi,
>
> Playing with the feature, I found a slightly irritating permutation -
> even if this code doesn't group any clauses, it may permute positions of
> the quals. See:
>
> DROP TABLE IF EXISTS main_tbl;
> CREATE TABLE main_tbl(id bigint, hundred int, thousand int);
> CREATE INDEX mt_hundred_ix ON main_tbl(hundred);
> CREATE INDEX mt_thousand_ix ON main_tbl(thousand);
> VACUUM (ANALYZE) main_tbl;
>
> SET enable_seqscan = off;
> EXPLAIN (COSTS OFF)
> SELECT m.id, m.hundred, m.thousand
> FROM main_tbl m WHERE (m.hundred < 2 OR m.thousand < 3);
>
>   Bitmap Heap Scan on public.main_tbl m
>     Output: id, hundred, thousand
>     Recheck Cond: ((m.thousand < 3) OR (m.hundred < 2))
>     ->  BitmapOr
>           ->  Bitmap Index Scan on mt_thousand_ix
>                 Index Cond: (m.thousand < 3)
>           ->  Bitmap Index Scan on mt_hundred_ix
>                 Index Cond: (m.hundred < 2)
>
> Conditions on the columns "thousand" and "hundred" changed their places
> according to the initial positions defined in the user's SQL.
> It isn't okay. I see that users often use the trick of "OR order" to
> avoid unnecessary calculations - most frequently, Subplan evaluations.
> So, it makes sense to fix.
> In the attachment, I have included a quick fix for this issue. Although
> many tests returned to their initial (pre-18) state, I added some tests
> specifically related to this issue to make it clearer.

I looked at your patch and have no objections to it.

However it's clearly stated in PostgreSQL manual that nothing about
the OR order is warranted [1]. So changing OR order was (and is) ok
and any users query tricks about OR order may work and may not work.

[1] https://www.postgresql.org/docs/17/sql-expressions.html#SYNTAX-EXPRESS-EVAL

Regards,
Pavel Borisov
Supabase



pgsql-hackers by date:

Previous
From: Vincent Moreau
Date:
Subject: [PATCH] Add a new pattern for zero-based months for Date/Time Formatting
Next
From: jian he
Date:
Subject: Re: support fast default for domain with constraints