From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Andres Freund <andres(at)anarazel(dot)de> |
Cc: | Michael Paquier <michael(at)paquier(dot)xyz>, exclusion(at)gmail(dot)com, pgsql-bugs(at)lists(dot)postgresql(dot)org |
Subject: | Re: BUG #17800: ON CONFLICT DO UPDATE fails to detect incompatible fields that leads to a server crash |
Date: | 2023-02-25 20:55:50 |
Message-ID: | 1416232.1677358550@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
Andres Freund <andres(at)anarazel(dot)de> writes:
> Your commit message referenced commit 3f7323cbb, which contains:
> That technique is borrowed from the far older code that supports
> initplans, and it works okay in that case because the cloned SubPlan nodes
> are essentially identical. So it doesn't matter which one of the clones
> the shared ParamExecData.execPlan field might point to.
Yeah, I now think that was a bit of a misstatement; not about the bug,
but about what happens with initplans.
> Out of curiosity: Are there cases where we actually overwrite execPlan for
> initplans? I couldn't find any with a quick assertion. ISTM that that largely
> should be prevented by initplans being initialized once, in ExecInitNode().
True. Even if an initplan is referenced in multiple places, it will be
attached to just one plan node's initPlan list, so there should be only
one time that execPlan gets set (per execution cycle of that node), and
I think only one SubPlanState that it could point to. The references
aren't SubPlan nodes, just Params.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Andres Freund | 2023-02-25 21:46:07 | Re: BUG #17800: ON CONFLICT DO UPDATE fails to detect incompatible fields that leads to a server crash |
Previous Message | Thomas Munro | 2023-02-25 20:38:01 | Re: BUG #17744: Fail Assert while recoverying from pg_basebackup |