aboutsummaryrefslogtreecommitdiff
path: root/src/backend/utils/adt/arrayfuncs.c
diff options
context:
space:
mode:
authorDavid Rowley <drowley@postgresql.org>2024-01-04 20:38:25 +1300
committerDavid Rowley <drowley@postgresql.org>2024-01-04 20:38:25 +1300
commitae69c4fcf1337af399a788ab8d96af540bd1cd8e (patch)
treecee1c57e2bb438f6206500b7b5b1cf421d2c6007 /src/backend/utils/adt/arrayfuncs.c
parent007693f2a3ac2ac19affcb03ad43cdb36ccff5b5 (diff)
downloadpostgresql-ae69c4fcf1337af399a788ab8d96af540bd1cd8e.tar.gz
postgresql-ae69c4fcf1337af399a788ab8d96af540bd1cd8e.zip
Fix use of incorrect TupleTableSlot in DISTINCT aggregates
1349d2790 added code to allow DISTINCT and ORDER BY aggregates to work more efficiently by using presorted input. That commit added some code that made use of the AggState's tmpcontext and adjusted the ecxt_outertuple and ecxt_innertuple slots before checking if the current row is distinct from the previously seen row. That code forgot to set the TupleTableSlots back to what they were originally, which could result in errors such as: ERROR: attribute 1 of type record has wrong type This only affects aggregate functions which have multiple arguments when DISTINCT is used. For example: string_agg(DISTINCT col, ', ') Thanks to Tom Lane for identifying the breaking commit. Bug: #18264 Reported-by: Vojtěch Beneš Discussion: https://postgr.es/m/18264-e363593d7e9feb7d@postgresql.org Backpatch-through: 16, where 1349d2790 was added
Diffstat (limited to 'src/backend/utils/adt/arrayfuncs.c')
0 files changed, 0 insertions, 0 deletions