summaryrefslogtreecommitdiff
path: root/contrib/pg_stat_statements
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2023-10-28 14:04:43 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2023-10-28 14:04:43 -0400
commitb7684473d74a7555e3fb7d1a492ef50d24bfce31 (patch)
treef068f2e234962236b4aa31b2ab7f365a23c93edb /contrib/pg_stat_statements
parentd946128734b661593628fd3e6e66162070b68676 (diff)
Fix intra-query memory leak when a SRF returns zero rows.
When looping around after finding that the set-returning function returned zero rows for the current input tuple, ExecProjectSet neglected to reset either of the two memory contexts it's responsible for cleaning out. Typically this wouldn't cause much problem, because once the SRF does return at least one row, the contexts would get reset on the next call. However, if the SRF returns no rows for many input tuples in succession, quite a lot of memory could be transiently consumed. To fix, make sure we reset both contexts while looping around. Per bug #18172 from Sergei Kornilov. Back-patch to all supported branches. Discussion: https://postgr.es/m/18172-9b8c5fc1d676ded3@postgresql.org
Diffstat (limited to 'contrib/pg_stat_statements')
0 files changed, 0 insertions, 0 deletions