Re: POC, WIP: OR-clause support for indexes

From: Alexander Korotkov <aekorotkov(at)gmail(dot)com>
To: Andrei Lepikhov <a(dot)lepikhov(at)postgrespro(dot)ru>
Cc: Alena Rybakina <a(dot)rybakina(at)postgrespro(dot)ru>, Nikolay Shaplov <dhyan(at)nataraj(dot)su>, pgsql-hackers(at)lists(dot)postgresql(dot)org, jian he <jian(dot)universality(at)gmail(dot)com>, Robert Haas <robertmhaas(at)gmail(dot)com>, pgsql-hackers(at)postgresql(dot)org, Peter Geoghegan <pg(at)bowt(dot)ie>, Marcos Pegoraro <marcos(at)f10(dot)com(dot)br>, teodor(at)sigaev(dot)ru, Tomas Vondra <tomas(dot)vondra(at)enterprisedb(dot)com>, Peter Eisentraut <peter(at)eisentraut(dot)org>, Ranier Vilela <ranier(dot)vf(at)gmail(dot)com>
Subject: Re: POC, WIP: OR-clause support for indexes
Date: 2024-08-21 14:52:03
Message-ID: CAPpHfdtR3cBKCSj_7dd7EDF_pa-rUUQBx3-guK6kZZ=_hSeMfg@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Wed, Aug 21, 2024 at 4:08 PM Andrei Lepikhov
<a(dot)lepikhov(at)postgrespro(dot)ru> wrote:
> On 21/8/2024 02:17, Alexander Korotkov wrote:
> > Also, I convert the check you've introduced in the previous message to
> > op_in_opfamily(), and introduced collation check similar to
> > match_opclause_to_indexcol().
> Hi,
> I passed through the patches with fresh sight. Conceptually, this
> approach looks much better than the previous series.
> Just for the record: previously, we attempted to resolve two issues in
> one - improve the execution plan and save cycles during the
> optimisation. As I see it, it is almost impossible in this feature. So,
> I should come to terms with carrying long OR lists through the planning
> and the additional overhead this feature generates.
> I also see that the optimiser has obtained additional planning
> strategies with these patches and hasn't lost any.

Thank you for your feedback.

> Couple of findings:
>
> First:
> /* Only operator clauses scan match */
> Should it be:
> /* Only operator clauses can match */
> ?

Corrected, thanks.

> The second one:
> When creating IndexClause, we assign the original and derived clauses to
> the new, containing transformed array. But logically, we should set the
> clause with a list of ORs as the original. Why did you do so?

I actually didn't notice that. Corrected to set the OR clause as the
original. That change turned recheck to use original OR clauses,
probably better this way. Also, that change spotted misuse of
RestrictInfo.clause and RestrictInfo.orclause in the second patch.
Corrected this too.

------
Regards,
Alexander Korotkov
Supabase

Attachment Content-Type Size
v36-0002-Teach-bitmap-path-generation-about-transforming-.patch application/octet-stream 22.9 KB
v36-0001-Transform-OR-clauses-to-SAOP-s-during-index-matc.patch application/octet-stream 41.6 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Tomas Vondra 2024-08-21 14:59:12 Re: Partial aggregates pushdown
Previous Message Joe Conway 2024-08-21 14:48:38 Re: Cutting support for OpenSSL 1.0.1 and 1.0.2 in 17~?