From b5aff9255700b0b3155a4d2be865b6a776c2bda4 Mon Sep 17 00:00:00 2001 From: David Rowley Date: Sat, 24 Dec 2022 13:18:35 +1300 Subject: [PATCH] Fix recent accidental omission in pg_proc.dat ed1a88dda added support functions for the ntile(), percent_rank() and cume_dist() window functions but neglected to actually add these support functions to the pg_proc entry for the corresponding window function. Also, take this opportunity to add these window functions to one of the regression tests added in ed1a88dda to give the support functions a little bit of exercise. If I'd done that in the first place then the omission would have been more obvious. Bump the catversion, again. --- src/include/catalog/catversion.h | 2 +- src/include/catalog/pg_proc.dat | 14 ++++++++------ src/test/regress/expected/window.out | 8 +++++++- src/test/regress/sql/window.sql | 8 +++++++- 4 files changed, 23 insertions(+), 9 deletions(-) diff --git a/src/include/catalog/catversion.h b/src/include/catalog/catversion.h index 1adf1403c8..e9206ff737 100644 --- a/src/include/catalog/catversion.h +++ b/src/include/catalog/catversion.h @@ -57,6 +57,6 @@ */ /* yyyymmddN */ -#define CATALOG_VERSION_NO 202212232 +#define CATALOG_VERSION_NO 202212241 #endif diff --git a/src/include/catalog/pg_proc.dat b/src/include/catalog/pg_proc.dat index 88bd472ecd..7056c95371 100644 --- a/src/include/catalog/pg_proc.dat +++ b/src/include/catalog/pg_proc.dat @@ -10204,20 +10204,22 @@ proname => 'window_dense_rank_support', prorettype => 'internal', proargtypes => 'internal', prosrc => 'window_dense_rank_support' }, { oid => '3103', descr => 'fractional rank within partition', - proname => 'percent_rank', prokind => 'w', proisstrict => 'f', - prorettype => 'float8', proargtypes => '', prosrc => 'window_percent_rank' }, + proname => 'percent_rank', prosupport => 'window_percent_rank_support', + prokind => 'w', proisstrict => 'f', prorettype => 'float8', + proargtypes => '', prosrc => 'window_percent_rank' }, { oid => '9773', descr => 'planner support for percent_rank', proname => 'window_percent_rank_support', prorettype => 'internal', proargtypes => 'internal', prosrc => 'window_percent_rank_support' }, { oid => '3104', descr => 'fractional row number within partition', - proname => 'cume_dist', prokind => 'w', proisstrict => 'f', - prorettype => 'float8', proargtypes => '', prosrc => 'window_cume_dist' }, + proname => 'cume_dist', prosupport => 'window_cume_dist_support', + prokind => 'w', proisstrict => 'f', prorettype => 'float8', + proargtypes => '', prosrc => 'window_cume_dist' }, { oid => '9774', descr => 'planner support for cume_dist', proname => 'window_cume_dist_support', prorettype => 'internal', proargtypes => 'internal', prosrc => 'window_cume_dist_support' }, { oid => '3105', descr => 'split rows into N groups', - proname => 'ntile', prokind => 'w', prorettype => 'int4', - proargtypes => 'int4', prosrc => 'window_ntile' }, + proname => 'ntile', prosupport => 'window_ntile_support', prokind => 'w', + prorettype => 'int4', proargtypes => 'int4', prosrc => 'window_ntile' }, { oid => '9775', descr => 'planner support for ntile', proname => 'window_ntile_support', prorettype => 'internal', proargtypes => 'internal', prosrc => 'window_ntile_support' }, diff --git a/src/test/regress/expected/window.out b/src/test/regress/expected/window.out index 776861808b..5505e9a2da 100644 --- a/src/test/regress/expected/window.out +++ b/src/test/regress/expected/window.out @@ -3326,7 +3326,13 @@ SELECT rank() OVER (PARTITION BY depname ORDER BY enroll_date ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING) rnk, dense_rank() OVER (PARTITION BY depname ORDER BY enroll_date RANGE BETWEEN - CURRENT ROW AND CURRENT ROW) drnk + CURRENT ROW AND CURRENT ROW) drnk, + ntile(10) OVER (PARTITION BY depname ORDER BY enroll_date RANGE BETWEEN + CURRENT ROW AND UNBOUNDED FOLLOWING) nt, + percent_rank() OVER (PARTITION BY depname ORDER BY enroll_date ROWS BETWEEN + CURRENT ROW AND UNBOUNDED FOLLOWING) pr, + cume_dist() OVER (PARTITION BY depname ORDER BY enroll_date RANGE BETWEEN + CURRENT ROW AND UNBOUNDED FOLLOWING) cd FROM empsalary; QUERY PLAN ---------------------------------------- diff --git a/src/test/regress/sql/window.sql b/src/test/regress/sql/window.sql index deaf2217a6..10f450fee4 100644 --- a/src/test/regress/sql/window.sql +++ b/src/test/regress/sql/window.sql @@ -987,7 +987,13 @@ SELECT rank() OVER (PARTITION BY depname ORDER BY enroll_date ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING) rnk, dense_rank() OVER (PARTITION BY depname ORDER BY enroll_date RANGE BETWEEN - CURRENT ROW AND CURRENT ROW) drnk + CURRENT ROW AND CURRENT ROW) drnk, + ntile(10) OVER (PARTITION BY depname ORDER BY enroll_date RANGE BETWEEN + CURRENT ROW AND UNBOUNDED FOLLOWING) nt, + percent_rank() OVER (PARTITION BY depname ORDER BY enroll_date ROWS BETWEEN + CURRENT ROW AND UNBOUNDED FOLLOWING) pr, + cume_dist() OVER (PARTITION BY depname ORDER BY enroll_date RANGE BETWEEN + CURRENT ROW AND UNBOUNDED FOLLOWING) cd FROM empsalary; -- Ensure WindowFuncs which cannot support their WindowClause's frameOptions