Commit 2a781d57 authored by Kevin Grittner's avatar Kevin Grittner

Acquire appropriate locks when rewriting during RMV.

Since the query has not been freshly parsed when executing REFRESH
MATERIALIZED VIEW, locks must be explicitly taken before rewrite.

Backpatch to 9.3.

Andres Freund
parent be420fa0
...@@ -283,6 +283,7 @@ refresh_matview_datafill(DestReceiver *dest, Query *query, ...@@ -283,6 +283,7 @@ refresh_matview_datafill(DestReceiver *dest, Query *query,
Oid save_userid; Oid save_userid;
int save_sec_context; int save_sec_context;
int save_nestlevel; int save_nestlevel;
Query *copied_query;
/* /*
* Switch to the owner's userid, so that any functions are run as that * Switch to the owner's userid, so that any functions are run as that
...@@ -294,8 +295,10 @@ refresh_matview_datafill(DestReceiver *dest, Query *query, ...@@ -294,8 +295,10 @@ refresh_matview_datafill(DestReceiver *dest, Query *query,
save_sec_context | SECURITY_RESTRICTED_OPERATION); save_sec_context | SECURITY_RESTRICTED_OPERATION);
save_nestlevel = NewGUCNestLevel(); save_nestlevel = NewGUCNestLevel();
/* Rewrite, copying the given Query to make sure it's not changed */ /* Lock and rewrite, using a copy to preserve the original query. */
rewritten = QueryRewrite((Query *) copyObject(query)); copied_query = copyObject(query);
AcquireRewriteLocks(copied_query, false);
rewritten = QueryRewrite(copied_query);
/* SELECT should never rewrite to more or less than one SELECT query */ /* SELECT should never rewrite to more or less than one SELECT query */
if (list_length(rewritten) != 1) if (list_length(rewritten) != 1)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment