Eliminate duplicative hashtempcxt in nodeSubplan.c.
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 10 Sep 2025 20:15:08 +0000 (16:15 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 10 Sep 2025 20:15:08 +0000 (16:15 -0400)
commitbdc6cfcd12f5c95799328e05aa4bfa75cfe3e79f
treef260c7d624eb02a654b1d6a4d8ab43a35700ff38
parentabdeacdb0920d94dec7500d09f6f29fbb2f6310d
Eliminate duplicative hashtempcxt in nodeSubplan.c.

Instead of building a separate memory context that's used just
for running hash functions, make the hash functions run in the
per-tuple context of the node's innerecontext.  This saves a
little space at runtime, and it avoids needing to reset two
contexts instead of one inside buildSubPlanHash's main loop.

This largely reverts commit 133924e13.  That's safe to do now
because bf6c614a2 decoupled the evaluation context used by
TupleHashTableMatch from that used for hash function evaluation,
so that there's no longer a risk of resetting the innerecontext
too soon.

Per discussion of bug #19040, although this is not directly
a fix for that.

Author: Tom Lane <tgl@sss.pgh.pa.us>
Reviewed-by: Haiyang Li <mohen.lhy@alibaba-inc.com>
Reviewed-by: Fei Changhong <feichanghong@qq.com>
Discussion: https://postgr.es/m/19040-c9b6073ef814f48c@postgresql.org
src/backend/executor/nodeSubplan.c
src/include/nodes/execnodes.h