]> granicus.if.org Git - postgresql/commit
Fix determination when slot types for upper executor nodes are fixed.
authorAndres Freund <andres@anarazel.de>
Sun, 29 Sep 2019 22:24:54 +0000 (15:24 -0700)
committerAndres Freund <andres@anarazel.de>
Sun, 29 Sep 2019 22:46:17 +0000 (15:46 -0700)
commit97e971ee05d5a0f6361ea34abf27059d762045a7
treee654f47b5cb3d52d91ad88823378535c646678ae
parent258bf86a9aec05b531c206a6e661ec8c0754e10f
Fix determination when slot types for upper executor nodes are fixed.

For many queries the fact that the tuple descriptor from the lower
node was not taken into account when determining whether the type of a
slot is fixed, lead to tuple deforming for such upper nodes not to be
JIT accelerated.

I broke this in 675af5c01e297.

There is ongoing work to enable writing regression tests for related
behavior (including a patch that would have detected this
regression), by optionally showing such details in EXPLAIN. But as it
seems unlikely that that will be suitable for stable branches, just
merge the fix for now.

While it's fairly close to the 12 release window, the fact that 11
continues to perform JITed tuple deforming in these cases, that
there's still cases where we do so in 12, and the fact that the
performance regression can be sizable, weigh in favor of fixing it
now.

Author: Andres Freund
Discussion: https://postgr.es/m/20190927072053.njf6prdl3vb7y7qb@alap3.anarazel.de
Backpatch: 12-, where 675af5c01e297 was merged.
src/backend/executor/execExpr.c