Calculate agglevelsup correctly when Aggref contains a CTE.
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 17 Sep 2025 20:32:57 +0000 (16:32 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 17 Sep 2025 20:32:57 +0000 (16:32 -0400)
commitb0cc0a71e0a0a760f54c72edb8cd000e4555442b
treeaba85c1d17a67facbf0e76e16ed2bdc954fbda4c
parent0951942bba25f85ad29a4f096ed51a356652b5a2
Calculate agglevelsup correctly when Aggref contains a CTE.

If an aggregate function call contains a sub-select that has
an RTE referencing a CTE outside the aggregate, we must treat
that reference like a Var referencing the CTE's query level
for purposes of determining the aggregate's level.  Otherwise
we might reach the nonsensical conclusion that the aggregate
should be evaluated at some query level higher than the CTE,
ending in a planner error or a broken plan tree that causes
executor failures.

Bug: #19055
Reported-by: BugForge <dllggyx@outlook.com>
Author: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/19055-6970cfa8556a394d@postgresql.org
Backpatch-through: 13
src/backend/parser/parse_agg.c
src/test/regress/expected/with.out
src/test/regress/sql/with.sql