diff --git a/GNUmakefile.in b/GNUmakefile.in index f63aa14e98e4..917773d6991b 100644 --- a/GNUmakefile.in +++ b/GNUmakefile.in @@ -12,6 +12,7 @@ $(call recurse,all install,src config) all: $(MAKE) -C contrib/auto_explain all + $(MAKE) -C contrib/pg_stat_statements all $(MAKE) -C contrib/citext all $(MAKE) -C contrib/file_fdw all $(MAKE) -C contrib/postgres_fdw all @@ -63,6 +64,7 @@ html man: install: $(MAKE) -C contrib/auto_explain $@ + $(MAKE) -C contrib/pg_stat_statements $@ $(MAKE) -C contrib/citext $@ $(MAKE) -C contrib/file_fdw $@ $(MAKE) -C contrib/postgres_fdw $@ @@ -182,6 +184,7 @@ $(call recurse,checkprep, src/test src/pl src/interfaces/ecpg contrib src/bin g # recipe body). ICW_TARGETS = src/test src/pl src/interfaces/gppc ICW_TARGETS += contrib/auto_explain contrib/citext contrib/btree_gin +ICW_TARGETS += contrib/pg_stat_statements ICW_TARGETS += contrib/file_fdw contrib/postgres_fdw contrib/formatter_fixedwidth ICW_TARGETS += contrib/extprotocol contrib/dblink contrib/pg_trgm ICW_TARGETS += contrib/indexscan contrib/hstore contrib/ltree contrib/pgcrypto contrib/isn diff --git a/contrib/pg_stat_statements/Makefile b/contrib/pg_stat_statements/Makefile index d19eec69d0b4..940a0fb99c8a 100644 --- a/contrib/pg_stat_statements/Makefile +++ b/contrib/pg_stat_statements/Makefile @@ -14,10 +14,12 @@ PGFILEDESC = "pg_stat_statements - execution statistics of SQL statements" LDFLAGS_SL += $(filter -lm, $(LIBS)) REGRESS_OPTS = --temp-config $(top_srcdir)/contrib/pg_stat_statements/pg_stat_statements.conf -REGRESS = pg_stat_statements olap_setup olap_group -# Disabled because these tests require "shared_preload_libraries=pg_stat_statements", -# which typical installcheck users do not have (e.g. buildfarm clients). -NO_INSTALLCHECK = 1 +REGRESS = enable_pg_stat_statements \ + pg_stat_statements \ + olap_setup \ + olap_group \ + jumble \ + disable_pg_stat_statements ifdef USE_PGXS PG_CONFIG = pg_config diff --git a/contrib/pg_stat_statements/expected/disable_pg_stat_statements.out b/contrib/pg_stat_statements/expected/disable_pg_stat_statements.out new file mode 100644 index 000000000000..8b137891791f --- /dev/null +++ b/contrib/pg_stat_statements/expected/disable_pg_stat_statements.out @@ -0,0 +1 @@ + diff --git a/contrib/pg_stat_statements/expected/enable_pg_stat_statements.out b/contrib/pg_stat_statements/expected/enable_pg_stat_statements.out new file mode 100644 index 000000000000..8b137891791f --- /dev/null +++ b/contrib/pg_stat_statements/expected/enable_pg_stat_statements.out @@ -0,0 +1 @@ + diff --git a/contrib/pg_stat_statements/expected/jumble.out b/contrib/pg_stat_statements/expected/jumble.out new file mode 100644 index 000000000000..89e119e58eff --- /dev/null +++ b/contrib/pg_stat_statements/expected/jumble.out @@ -0,0 +1,138 @@ +CREATE TABLE t(a int, b text) DISTRIBUTED BY (a); +SELECT pg_stat_statements_reset(); + pg_stat_statements_reset +-------------------------- + +(1 row) + +SELECT GROUPING (a) FROM t GROUP BY ROLLUP(a, b); + grouping +---------- + 1 +(1 row) + +-- launch not equivalent query +SELECT GROUPING (b) FROM t GROUP BY ROLLUP(a, b); + grouping +---------- + 1 +(1 row) + +-- check group_id() in a query +SELECT group_id() FROM t GROUP BY ROLLUP(a, b); + group_id +---------- + 0 +(1 row) + +-- check that queries have separate entries +SELECT query, calls FROM pg_stat_statements ORDER BY query; + query | calls +--------------------------------------------------+------- + SELECT group_id() FROM t GROUP BY ROLLUP(a, b) | 1 + SELECT GROUPING (a) FROM t GROUP BY ROLLUP(a, b) | 1 + SELECT GROUPING (b) FROM t GROUP BY ROLLUP(a, b) | 1 + SELECT pg_stat_statements_reset() | 1 +(4 rows) + +SELECT pg_stat_statements_reset(); + pg_stat_statements_reset +-------------------------- + +(1 row) + +-- check that different grouping options result in separate entries +SELECT COUNT (*) FROM t GROUP BY ROLLUP(a, b); + count +------- + 0 +(1 row) + +SELECT COUNT (*) FROM t GROUP BY CUBE(a, b); + count +------- + 0 +(1 row) + +SELECT COUNT (*) FROM t GROUP BY GROUPING SETS(a, b); + count +------- +(0 rows) + +SELECT COUNT (*) FROM t GROUP BY GROUPING SETS((a), (a, b)); + count +------- +(0 rows) + +SELECT COUNT (*) FROM t GROUP BY a, b; + count +------- +(0 rows) + +SELECT query, calls FROM pg_stat_statements ORDER BY query; + query | calls +-------------------------------------------------------------+------- + SELECT COUNT (*) FROM t GROUP BY a, b | 1 + SELECT COUNT (*) FROM t GROUP BY CUBE(a, b) | 1 + SELECT COUNT (*) FROM t GROUP BY GROUPING SETS((a), (a, b)) | 1 + SELECT COUNT (*) FROM t GROUP BY GROUPING SETS(a, b) | 1 + SELECT COUNT (*) FROM t GROUP BY ROLLUP(a, b) | 1 + SELECT pg_stat_statements_reset() | 1 +(6 rows) + +-- check several parameters options in ROLLUP +-- all should result in separate entries +SELECT pg_stat_statements_reset(); + pg_stat_statements_reset +-------------------------- + +(1 row) + +SELECT COUNT (*) FROM t GROUP BY ROLLUP(a, b); + count +------- + 0 +(1 row) + +SELECT COUNT (*) FROM t GROUP BY ROLLUP(b); + count +------- + 0 +(1 row) + +SELECT query, calls FROM pg_stat_statements ORDER BY query; + query | calls +-----------------------------------------------+------- + SELECT COUNT (*) FROM t GROUP BY ROLLUP(a, b) | 1 + SELECT COUNT (*) FROM t GROUP BY ROLLUP(b) | 1 + SELECT pg_stat_statements_reset() | 1 +(3 rows) + +--- check anytable parameter for a function +SELECT pg_stat_statements_reset(); + pg_stat_statements_reset +-------------------------- + +(1 row) + +-- call of anytable_out will cause an error, +-- thus prevent actual call by adding FALSE condition +SELECT * FROM anytable_out(TABLE(SELECT * FROM t)) WHERE 1 = 0; + anytable_out +-------------- +(0 rows) + +SELECT * FROM anytable_out(TABLE(SELECT * FROM t WHERE a=0)) WHERE 1 = 0; + anytable_out +-------------- +(0 rows) + +SELECT query, calls FROM pg_stat_statements ORDER BY query; + query | calls +-----------------------------------------------------------------------------+------- + SELECT * FROM anytable_out(TABLE(SELECT * FROM t)) WHERE $1 = $2 | 1 + SELECT * FROM anytable_out(TABLE(SELECT * FROM t WHERE a=$1)) WHERE $2 = $3 | 1 + SELECT pg_stat_statements_reset() | 1 +(3 rows) + +DROP TABLE t; diff --git a/contrib/pg_stat_statements/sql/disable_pg_stat_statements.sql b/contrib/pg_stat_statements/sql/disable_pg_stat_statements.sql new file mode 100644 index 000000000000..8c5042276dc1 --- /dev/null +++ b/contrib/pg_stat_statements/sql/disable_pg_stat_statements.sql @@ -0,0 +1,5 @@ +-- start_ignore +\! gpconfig -r shared_preload_libraries; +\! gpconfig -r optimizer; +\! gpstop -raq -M fast; +-- end_ignore \ No newline at end of file diff --git a/contrib/pg_stat_statements/sql/enable_pg_stat_statements.sql b/contrib/pg_stat_statements/sql/enable_pg_stat_statements.sql new file mode 100644 index 000000000000..653423bf767b --- /dev/null +++ b/contrib/pg_stat_statements/sql/enable_pg_stat_statements.sql @@ -0,0 +1,7 @@ +-- start_ignore +\! gpconfig -c shared_preload_libraries -v 'pg_stat_statements'; +-- Known issue: query is not added to pg_stat_statements statistics in +-- case it is planned by GPORCA. So disable GPORCA during tests. +\! gpconfig -c optimizer -v off; +\! gpstop -raq -M fast; +-- end_ignore \ No newline at end of file diff --git a/contrib/pg_stat_statements/sql/jumble.sql b/contrib/pg_stat_statements/sql/jumble.sql new file mode 100644 index 000000000000..a61dd476c380 --- /dev/null +++ b/contrib/pg_stat_statements/sql/jumble.sql @@ -0,0 +1,48 @@ +-- start_ignore +CREATE EXTENSION IF NOT EXISTS pg_stat_statements; +DROP TABLE IF EXISTS t; +-- end_ignore +CREATE TABLE t(a int, b text) DISTRIBUTED BY (a); + +SELECT pg_stat_statements_reset(); + +SELECT GROUPING (a) FROM t GROUP BY ROLLUP(a, b); +-- launch not equivalent query +SELECT GROUPING (b) FROM t GROUP BY ROLLUP(a, b); +-- check group_id() in a query +SELECT group_id() FROM t GROUP BY ROLLUP(a, b); + +-- check that queries have separate entries +SELECT query, calls FROM pg_stat_statements ORDER BY query; + +SELECT pg_stat_statements_reset(); + +-- check that different grouping options result in separate entries +SELECT COUNT (*) FROM t GROUP BY ROLLUP(a, b); +SELECT COUNT (*) FROM t GROUP BY CUBE(a, b); +SELECT COUNT (*) FROM t GROUP BY GROUPING SETS(a, b); +SELECT COUNT (*) FROM t GROUP BY GROUPING SETS((a), (a, b)); +SELECT COUNT (*) FROM t GROUP BY a, b; + +SELECT query, calls FROM pg_stat_statements ORDER BY query; + +-- check several parameters options in ROLLUP +-- all should result in separate entries +SELECT pg_stat_statements_reset(); + +SELECT COUNT (*) FROM t GROUP BY ROLLUP(a, b); +SELECT COUNT (*) FROM t GROUP BY ROLLUP(b); + +SELECT query, calls FROM pg_stat_statements ORDER BY query; + +--- check anytable parameter for a function +SELECT pg_stat_statements_reset(); + +-- call of anytable_out will cause an error, +-- thus prevent actual call by adding FALSE condition +SELECT * FROM anytable_out(TABLE(SELECT * FROM t)) WHERE 1 = 0; +SELECT * FROM anytable_out(TABLE(SELECT * FROM t WHERE a=0)) WHERE 1 = 0; + +SELECT query, calls FROM pg_stat_statements ORDER BY query; + +DROP TABLE t; diff --git a/src/backend/utils/misc/queryjumble.c b/src/backend/utils/misc/queryjumble.c index 96ed1a2c825b..354d1efa5534 100644 --- a/src/backend/utils/misc/queryjumble.c +++ b/src/backend/utils/misc/queryjumble.c @@ -185,6 +185,7 @@ JumbleRangeTable(JumbleState *jstate, List *rtable) APP_JUMB(rte->jointype); break; case RTE_FUNCTION: + case RTE_TABLEFUNCTION: JumbleExpr(jstate, (Node *) rte->functions); break; case RTE_TABLEFUNC: @@ -646,6 +647,7 @@ JumbleExpr(JumbleState *jstate, Node *node) { GroupingSet *gsnode = (GroupingSet *) node; + APP_JUMB(gsnode->kind); JumbleExpr(jstate, (Node *) gsnode->content); } break; @@ -706,6 +708,13 @@ JumbleExpr(JumbleState *jstate, Node *node) JumbleExpr(jstate, (Node *) tsc->repeatable); } break; + case T_TableValueExpr: + { + TableValueExpr *tve = (TableValueExpr *) node; + + JumbleQueryInternal(jstate, (Query *) tve->subquery); + } + break; default: /* Only a warning, since we can stumble along anyway */ elog(WARNING, "unrecognized node type: %d",