From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | David Geier <david(at)swarm64(dot)com> |
Cc: | pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: search_plan_tree(): handling of non-leaf CustomScanState nodes causes segfault |
Date: | 2021-01-18 22:42:10 |
Message-ID: | 416507.1611009730@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
David Geier <david(at)swarm64(dot)com> writes:
> On 18.01.21 19:46, Tom Lane wrote:
>> Hm. I agree that we shouldn't simply assume that ss_currentRelation
>> isn't null. However, we cannot make search_plan_tree() descend
>> through non-leaf CustomScan nodes, because we don't know what processing
>> is involved there. We need to find a scan that is guaranteed to return
>> rows that are one-to-one with the cursor output. This is why the function
>> doesn't descend through join or aggregation nodes, and I see no argument
>> by which we should assume we know more about what a customscan node will
>> do than we know about those.
> That makes sense. Thanks for the explanation.
OK, cool. I was afraid you'd argue that you really needed your CustomScan
node to be transparent in such cases. We could imagine inventing an
additional custom-scan-provider callback to embed the necessary knowledge,
but I'd rather not add the complexity until someone has a use-case.
> I updated the patch to match your proposal.
WFM, will push in a bit.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Kincaid | 2021-01-18 22:47:34 | Re: Key management with tests |
Previous Message | Alvaro Herrera | 2021-01-18 22:40:05 | Re: Odd, intermittent failure in contrib/pageinspect |