Set query ID for inner queries of CREATE TABLE AS and DECLARE
authorMichael Paquier <michael@paquier.xyz>
Mon, 28 Oct 2024 00:03:20 +0000 (09:03 +0900)
committerMichael Paquier <michael@paquier.xyz>
Mon, 28 Oct 2024 00:03:20 +0000 (09:03 +0900)
commit6b652e6ce85a977e4ca7b8cc045cf4f3457b2d7b
tree4bfc5d62944f27cf0fd838046eb9e95bae034bac
parent33b2fbe0504bd349c3bb86e8711f5531c8ca84b7
Set query ID for inner queries of CREATE TABLE AS and DECLARE

Some utility statements contain queries that can be planned and
executed: CREATE TABLE AS and DECLARE CURSOR.  This commit adds query ID
computation for the inner queries executed by these two utility
commands, with and without EXPLAIN.  This change leads to four new
callers of JumbleQuery() and post_parse_analyze_hook() so as extensions
can decide what to do with this new data.

Previously, extensions relying on the query ID, like pg_stat_statements,
were not able to track these nested queries as the query_id was 0.

For pg_stat_statements, this commit leads to additions under !toplevel
when pg_stat_statements.track is set to "all", as shown in its
regression tests.  The output of EXPLAIN for these two utilities gains a
"Query Identifier" if compute_query_id is enabled.

Author: Anthonin Bonnefoy
Reviewed-by: Michael Paquier, Jian He
Discussion: https://postgr.es/m/CAO6_XqqM6S9bQ2qd=75W+yKATwoazxSNhv5sjW06fjGAtHbTUA@mail.gmail.com
contrib/pg_stat_statements/expected/level_tracking.out
src/backend/commands/createas.c
src/backend/commands/explain.c
src/backend/commands/portalcmds.c
src/backend/commands/prepare.c
src/include/commands/explain.h
src/include/commands/prepare.h
src/test/regress/expected/explain.out
src/test/regress/sql/explain.sql