mirror of
https://github.com/postgres/postgres.git
synced 2025-06-13 07:41:39 +03:00
Fix crash in postgres_fdw for provably-empty remote UPDATE/DELETE.
In 86dc90056
, I'd written find_modifytable_subplan with the assumption
that if the immediate child of a ModifyTable is a Result, it must be
a projecting Result with a subplan. However, if the UPDATE or DELETE
has a provably-constant-false WHERE clause, that's not so: we'll
generate a dummy subplan with a childless Result. Add the missing
null-check so we don't crash on such cases.
Per report from Alexander Pyhalov.
Discussion: https://postgr.es/m/b9a6f53549456b2f3e2fd150dcd79d72@postgrespro.ru
This commit is contained in:
@ -2370,7 +2370,9 @@ find_modifytable_subplan(PlannerInfo *root,
|
||||
if (subplan_index < list_length(appendplan->appendplans))
|
||||
subplan = (Plan *) list_nth(appendplan->appendplans, subplan_index);
|
||||
}
|
||||
else if (IsA(subplan, Result) && IsA(outerPlan(subplan), Append))
|
||||
else if (IsA(subplan, Result) &&
|
||||
outerPlan(subplan) != NULL &&
|
||||
IsA(outerPlan(subplan), Append))
|
||||
{
|
||||
Append *appendplan = (Append *) outerPlan(subplan);
|
||||
|
||||
|
Reference in New Issue
Block a user