pgsql: Set query ID for inner queries of CREATE TABLE AS and DECLARE - Mailing list pgsql-committers

From Michael Paquier
Subject pgsql: Set query ID for inner queries of CREATE TABLE AS and DECLARE
Date
Msg-id E1t5DF2-002lHQ-Dc@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
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

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/6b652e6ce85a977e4ca7b8cc045cf4f3457b2d7b

Modified Files
--------------
.../pg_stat_statements/expected/level_tracking.out | 12 ++++--
src/backend/commands/createas.c                    | 10 +++++
src/backend/commands/explain.c                     | 43 ++++++++++++++--------
src/backend/commands/portalcmds.c                  | 10 +++++
src/backend/commands/prepare.c                     | 20 +++++-----
src/include/commands/explain.h                     |  4 +-
src/include/commands/prepare.h                     |  4 +-
src/test/regress/expected/explain.out              | 17 +++++++++
src/test/regress/sql/explain.sql                   |  4 ++
9 files changed, 89 insertions(+), 35 deletions(-)


pgsql-committers by date:

Previous
From: Peter Geoghegan
Date:
Subject: pgsql: Fix obsolete nbtree split buffer comment.
Next
From: Amit Kapila
Date:
Subject: pgsql: Change the default value of the streaming option to 'parallel'.