postgresql/contrib/pg_stat_statements/expected
Tom Lane 76db9cb636 Fix some issues with tracking nesting level in pg_stat_statements.
When we decide that we don't want to track execution time of a
specific planner or ProcessUtility call, we still have to increment
the nesting depth, or we'll make the wrong determination of whether
we are at top level when considering nested statements.  (PREPARE
and EXECUTE are exceptions, for reasons explained in the code.)

Counting planner nesting depth separately from executor nesting depth
was a mistake: it causes us to make the wrong determination of whether
we are at top level when considering nested statements that get
executed during planning (as a result of constant-folding of
functions, for example).  Merge those counters into one.

In passing, get rid of the PGSS_HANDLED_UTILITY macro in favor of
explicitly listing statement types.  It seems somewhat coincidental
that PREPARE and EXECUTE are handled alike in each of the places where
that was used: the reasoning tends to be different for each one.
Thus, the macro seems as likely to encourage future bugs as prevent
them, since it's quite unclear whether any future statement type that
might need special-casing here would also need the same choices at
each spot.

Sergei Kornilov, Julien Rouhaud, and Tom Lane, per bug #17552 from
Maxim Boguk.  This is pretty clearly a bug fix, but it's also a
behavioral change that might surprise somebody, so no back-patch.

Discussion: https://postgr.es/m/17552-213b534c56ab5d02@postgresql.org
2023-11-08 12:01:28 -05:00
..
cleanup.out Refactor tests of pg_stat_statements for planning, utility and level tracking 2023-02-20 09:28:29 +09:00
cursors.out Reflect normalization of query strings for utilities in pg_stat_statements 2023-03-08 15:00:50 +09:00
dml.out Fix tracking of temp table relation extensions as writes 2023-09-13 19:14:09 -07:00
level_tracking.out Fix some issues with tracking nesting level in pg_stat_statements. 2023-11-08 12:01:28 -05:00
oldextversions.out pg_stat_statements: Add local_blk_{read|write}_time 2023-10-19 14:03:31 +09:00
planning.out Refactor tests of pg_stat_statements for planning, utility and level tracking 2023-02-20 09:28:29 +09:00
select.out Refactor more the regression tests of pg_stat_statements 2023-03-03 08:46:11 +09:00
user_activity.out Improve cleanup phases in regression tests of pg_stat_statements 2023-03-07 08:58:13 +09:00
utility.out Show parameters of CALL as constants in pg_stat_statements 2023-09-28 15:17:55 +09:00
wal.out Improve cleanup phases in regression tests of pg_stat_statements 2023-03-07 08:58:13 +09:00