1
0
mirror of https://github.com/postgres/postgres.git synced 2025-05-05 09:19:17 +03:00

Skip allocating hash table in EXPLAIN-only mode.

This is a backpatch of commit 2cccb627f1, backpatched due to popular
demand. Backpatch to all supported versions.

Author: Alexey Bashtanov
Discussion: https://www.postgresql.org/message-id/36823f65-050d-ae24-aa4d-a37726998240%40imap.cc
This commit is contained in:
Heikki Linnakangas 2020-11-20 14:41:14 +02:00
parent 9e9a31bd00
commit 340ae3cfb8

View File

@ -3665,7 +3665,11 @@ ExecInitAgg(Agg *node, EState *estate, int eflags)
&aggstate->hash_ngroups_limit, &aggstate->hash_ngroups_limit,
&aggstate->hash_planned_partitions); &aggstate->hash_planned_partitions);
find_hash_columns(aggstate); 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; aggstate->table_filled = false;
/* Initialize this to 1, meaning nothing spilled, yet */ /* Initialize this to 1, meaning nothing spilled, yet */