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 |
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~? |