aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>2020-11-18 12:39:15 +0200
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>2020-11-18 12:39:15 +0200
commit2cccb627f10d5dd4c21806fa251e4fb61eadd28c (patch)
tree2de97eb1eeb8d310a2711f814f11f66f0292f275
parentdfab7f2f94812c6c3a62cfde0ec7f9e447132e64 (diff)
downloadpostgresql-2cccb627f10d5dd4c21806fa251e4fb61eadd28c.tar.gz
postgresql-2cccb627f10d5dd4c21806fa251e4fb61eadd28c.zip
Skip allocating hash table in EXPLAIN-only mode.
Author: Alexey Bashtanov Discussion: https://www.postgresql.org/message-id/36823f65-050d-ae24-aa4d-a37726998240%40imap.cc
-rw-r--r--src/backend/executor/nodeAgg.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/backend/executor/nodeAgg.c b/src/backend/executor/nodeAgg.c
index d87677d6599..5bf9e99bbc8 100644
--- a/src/backend/executor/nodeAgg.c
+++ b/src/backend/executor/nodeAgg.c
@@ -3665,7 +3665,11 @@ ExecInitAgg(Agg *node, EState *estate, int eflags)
&aggstate->hash_ngroups_limit,
&aggstate->hash_planned_partitions);
find_hash_columns(aggstate);
- build_hash_tables(aggstate);
+
+ /* Skip massive memory allocation if we are just doing EXPLAIN */
+ if (!(eflags & EXEC_FLAG_EXPLAIN_ONLY))
+ build_hash_tables(aggstate);
+
aggstate->table_filled = false;
/* Initialize this to 1, meaning nothing spilled, yet */