diff --git a/src/backend/executor/execMain.c b/src/backend/executor/execMain.c index 19bfcd3e5ba..3aec47d8277 100644 --- a/src/backend/executor/execMain.c +++ b/src/backend/executor/execMain.c @@ -704,6 +704,10 @@ InitPlan(QueryDesc *queryDesc, int eflags) if (rc->isParent) continue; + /* + * If you change the conditions under which rel locks are acquired + * here, be sure to adjust ExecOpenScanRelation to match. + */ switch (rc->markType) { case ROW_MARK_EXCLUSIVE: diff --git a/src/backend/executor/execUtils.c b/src/backend/executor/execUtils.c index bdd7b1cdefd..283c882d1e5 100644 --- a/src/backend/executor/execUtils.c +++ b/src/backend/executor/execUtils.c @@ -816,7 +816,9 @@ ExecOpenScanRelation(EState *estate, Index scanrelid) { ExecRowMark *erm = lfirst(l); - if (erm->rti == scanrelid) + /* Keep this check in sync with InitPlan! */ + if (erm->rti == scanrelid && + erm->relation != NULL) { lockmode = NoLock; break;