From: | Alena Rybakina <a(dot)rybakina(at)postgrespro(dot)ru> |
---|---|
To: | Nikolay Shaplov <dhyan(at)nataraj(dot)su>, pgsql-hackers(at)lists(dot)postgresql(dot)org |
Cc: | Alexander Korotkov <aekorotkov(at)gmail(dot)com>, Andrei Lepikhov <a(dot)lepikhov(at)postgrespro(dot)ru>, 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>, "Finnerty, Jim" <jfinnert(at)amazon(dot)com>, 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-07-11 16:17:42 |
Message-ID: | 3b9bb831-da52-4779-8f3e-f8b6b83ba41f@postgrespro.ru |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
Hi, again!
I have finished patch and processed almost your suggestions (from [0],
[1], [2]). It remainsonlyto addtestswherethe conversionshouldwork,butI
willaddthis inthe nextversion.
[0]
https://www.postgresql.org/message-id/3381819.e9J7NaK4W3%40thinkpad-pgpro
[1]
https://www.postgresql.org/message-id/9736220.CDJkKcVGEf%40thinkpad-pgpro
[2]
https://www.postgresql.org/message-id/2193851.QkHrqEjB74%40thinkpad-pgpro
On 09.07.2024 04:57, Alena Rybakina wrote:
>
> Hi! Thank you for your review! Sorryforthe delayin responding.
>
> Irewrotethe patchasyourequested,butnowI'm facedwiththe problemof
> processingthe elementsof the or_entries list.For somereason,
> thepointerto thelistis cleared and I couldn't find the place where it
> happened.MaybeI'mmissingsomethingsimpleinviewof the heavyworkloadright
> now,butmaybeyou'll seea problem?Ihave displayedpart of stackbelow.
>
> #5 0x00005b0f6d9f6a6a in ExceptionalCondition
> (conditionName=0x5b0f6dbb74f7 "IsPointerList(list)",
> fileName=0x5b0f6dbb7418 "list.c", lineNumber=341) at assert.c:66 #6
> 0x00005b0f6d5dc3ba in lappend (list=0x5b0f6eec5ca0,
> datum=0x5b0f6eec0d90) at list.c:341 #7 0x00005b0f6d69230c in
> transform_or_to_any (root=0x5b0f6eeb13c8, orlist=0x5b0f6eec57c0) at
> initsplan.c:2818 #8 0x00005b0f6d692958 in add_base_clause_to_rel
> (root=0x5b0f6eeb13c8, relid=1, restrictinfo=0x5b0f6eec5990) at
> initsplan.c:2982 #9 0x00005b0f6d692e5f in
> distribute_restrictinfo_to_rels (root=0x5b0f6eeb13c8,
> restrictinfo=0x5b0f6eec5990) at initsplan.c:3175 #10
> 0x00005b0f6d691bf2 in distribute_qual_to_rels (root=0x5b0f6eeb13c8,
> clause=0x5b0f6eec0fc0, jtitem=0x5b0f6eec4330, sjinfo=0x0,
> security_level=0, qualscope=0x5b0f6eec4730, ojscope=0x0,
> outerjoin_nonnullable=0x0, incompatible_relids=0x0,
> allow_equivalence=true, has_clone=false, is_clone=false,
> postponed_oj_qual_list=0x0) at initsplan.c:2576 #11 0x00005b0f6d69146f
> in distribute_quals_to_rels (root=0x5b0f6eeb13c8,
> clauses=0x5b0f6eec0bb0, jtitem=0x5b0f6eec4330, sjinfo=0x0,
> security_level=0, qualscope=0x5b0f6eec4730, ojscope=0x0,
> outerjoin_nonnullable=0x0, incompatible_relids=0x0,
> allow_equivalence=true, has_clone=false, is_clone=false,
> postponed_oj_qual_list=0x0) at initsplan.c:2144
>
> Thisis stillthe firstiterationof the fixesyouhave proposed,soI have
> attachedthe patchindiffformat.I rewroteit,asyousuggestedinthe
> firstletter[0].Icreateda separatefunctionthattriesto forman
> OrClauseGroup node,butifit failsinthis, it returnsfalse,otherwiseit
> processesthe generatedelementaccordingtowhat it found-eitheraddsit to
> thelistasnew,oraddsa constantto anexistingone.
>
> Ialsodividedonegenerallistof
> suitableforconversionandunsuitableintotwodifferentones:appropriate_entriesandor_entries.Nowweare
> onlylookinginthe listof suitableelementstoformANYexpr.
>
> Thishelpsusto get ridofrepetitionsinthe codeyoumentioned.
> Pleasewriteifthisis notthelogicthatyouhave seenbefore.
>
> [0]
> https://www.postgresql.org/message-id/3381819.e9J7NaK4W3%40thinkpad-pgpro
>
The errorwascausedby the specificsof storingthe "OR"clausesinthe
RestrictInfostructure.Scanning the orclauses list of the RestrictInfo
variable, wecouldfacenotonlytheitem with RestrictInfo
type,butalsotheBoolExpr type.
For example, when we have both or clauses and "AND" clauses together,
like x = 1 and (y =1 or y=2 or y=3 and z = 1). The structure looks like:
RestrictInfo->orclauses = [RestrictInfo [x=1],
RestrictInfo->orclauses = [RestrictInfo[y=1],
RestrictInfo [y=2],
BoolExpr = [Restrictinfo [y=3], RestrictInfo [z=1]
]
]
It'sworkingfinenow.
--
Regards,
Alena Rybakina
Postgres Professional:http://www.postgrespro.com
The Russian Postgres Company
Attachment | Content-Type | Size |
---|---|---|
v26-0001-Transform-OR-clauses-to-ANY-expression.patch | text/x-patch | 24.7 KB |
v26-0002-Add-some-new-tests-to-check-the-functionality-of.patch | text/x-patch | 3.5 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | Andrew Dunstan | 2024-07-11 16:28:28 | Re: CFbot failed on Windows platform |
Previous Message | Robert Haas | 2024-07-11 16:16:33 | Re: Add a GUC check hook to ensure summarize_wal cannot be enabled when wal_level is minimal |