mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Previously, a Query generated through the transform phase would have
unset stmt_location, tracking the starting point of a query string.
Extensions relying on the statement location to extract its relevant
parts in the source text string would fallback to use the whole
statement instead, leading to confusing results like in
pg_stat_statements for queries relying on nested queries, like:
- EXPLAIN, with top-level and nested query using the same query string,
and a query ID coming from the nested query when the non-top-level
entry.
- Multi-statements, with only partial portions of queries being
normalized.
- COPY TO with a query, SELECT or DMLs.
This patch improves things by keeping track of the statement locations
and propagate it to Query during transform, allowing PGSS to only show
the relevant part of the query for nested query.  This leads to less
bloat in entries for non-top-level entries, as queries can now be
grouped within the same (toplevel, queryid) duos in pg_stat_statements.
The result gives a stricter one-one mapping between query IDs and its
query strings.
The regression tests introduced in 45e0ba30fc produce differences
reflecting the new logic.
Author: Anthonin Bonnefoy
Reviewed-by: Michael Paquier, Jian He
Discussion: https://postgr.es/m/CAO6_XqqM6S9bQ2qd=75W+yKATwoazxSNhv5sjW06fjGAtHbTUA@mail.gmail.com
		
	
		
			
				
	
	
		
			32 lines
		
	
	
		
			925 B
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			925 B
		
	
	
	
		
			SQL
		
	
	
	
	
	
| --
 | |
| -- Information related to planning
 | |
| --
 | |
| 
 | |
| -- These tests require track_planning to be enabled.
 | |
| SET pg_stat_statements.track_planning = TRUE;
 | |
| SELECT pg_stat_statements_reset() IS NOT NULL AS t;
 | |
| 
 | |
| --
 | |
| -- [re]plan counting
 | |
| --
 | |
| CREATE TABLE stats_plan_test ();
 | |
| PREPARE prep1 AS SELECT COUNT(*) FROM stats_plan_test;
 | |
| EXECUTE prep1;
 | |
| EXECUTE prep1;
 | |
| EXECUTE prep1;
 | |
| ALTER TABLE stats_plan_test ADD COLUMN x int;
 | |
| EXECUTE prep1;
 | |
| SELECT 42;
 | |
| SELECT 42;
 | |
| SELECT 42;
 | |
| SELECT plans, calls, rows, query FROM pg_stat_statements
 | |
|   WHERE query NOT LIKE 'SELECT COUNT%' ORDER BY query COLLATE "C";
 | |
| -- for the prepared statement we expect at least one replan, but cache
 | |
| -- invalidations could force more
 | |
| SELECT plans >= 2 AND plans <= calls AS plans_ok, calls, rows, query FROM pg_stat_statements
 | |
|   WHERE query LIKE 'SELECT COUNT%' ORDER BY query COLLATE "C";
 | |
| 
 | |
| -- Cleanup
 | |
| DROP TABLE stats_plan_test;
 | |
| SELECT pg_stat_statements_reset() IS NOT NULL AS t;
 |