diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 18:00:34 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 18:00:34 +0000 |
commit | 3f619478f796eddbba6e39502fe941b285dd97b1 (patch) | |
tree | e2c7b5777f728320e5b5542b6213fd3591ba51e2 /mysql-test/main/win_min_max.test | |
parent | Initial commit. (diff) | |
download | mariadb-upstream.tar.xz mariadb-upstream.zip |
Adding upstream version 1:10.11.6.upstream/1%10.11.6upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'mysql-test/main/win_min_max.test')
-rw-r--r-- | mysql-test/main/win_min_max.test | 370 |
1 files changed, 370 insertions, 0 deletions
diff --git a/mysql-test/main/win_min_max.test b/mysql-test/main/win_min_max.test new file mode 100644 index 00000000..8efde87f --- /dev/null +++ b/mysql-test/main/win_min_max.test @@ -0,0 +1,370 @@ +create table t1 ( + pk int primary key, + a int, + b int, + c real +); + + +insert into t1 values +(101 , 0, 10, 1.1), +(102 , 0, 10, 2.1), +(103 , 1, 10, 3.1), +(104 , 1, 10, 4.1), +(108 , 2, 10, 5.1), +(105 , 2, 20, 6.1), +(106 , 2, 20, 7.1), +(107 , 2, 20, 8.15), +(109 , 4, 20, 9.15), +(110 , 4, 20, 10.15), +(111 , 5, NULL, 11.15), +(112 , 5, 1, 12.25), +(113 , 5, NULL, 13.35), +(114 , 5, NULL, 14.50), +(115 , 5, NULL, 15.65), +(116 , 6, 1, NULL), +(117 , 6, 1, 10), +(118 , 6, 1, 1.1), +(119 , 6, 1, NULL), +(120 , 6, 1, NULL), +(121 , 6, 1, NULL), +(122 , 6, 1, 2.2), +(123 , 6, 1, 20.1), +(124 , 6, 1, -10.4), +(125 , 6, 1, NULL), +(126 , 6, 1, NULL), +(127 , 6, 1, NULL); + + +--sorted_result +select pk, a, b, min(b) over (partition by a order by pk ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) as min, + max(b) over (partition by a order by pk ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) as max +from t1; + +--sorted_result +select pk, a, c, min(c) over (partition by a order by pk ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) as min, + max(c) over (partition by a order by pk ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) as max +from t1; + +create table t2 ( + pk int primary key, + a int, + b int, + c char(10) +); + +insert into t2 values +( 1, 0, 1, 'one'), +( 2, 0, 2, 'two'), +( 3, 0, 3, 'three'), +( 4, 1, 20, 'four'), +( 5, 1, 10, 'five'), +( 6, 1, 40, 'six'), +( 7, 1, 30, 'seven'), +( 8, 4,300, 'eight'), +( 9, 4,100, 'nine'), +(10, 4,200, 'ten'), +(11, 4,200, 'eleven'); + +--echo # First try some invalid argument queries. +select pk, a, b, c, + min(c) over (order by pk), + max(c) over (order by pk), + min(c) over (partition by a order by pk), + max(c) over (partition by a order by pk) +from t2; + + + +--echo # Empty frame + +select pk, a, b, c, + min(b) over (order by pk rows between 2 following and 1 following) as min1, + max(b) over (order by pk rows between 2 following and 1 following) as max1, + min(b) over (partition by a order by pk rows between 2 following and 1 following) as min2, + max(b) over (partition by a order by pk rows between 2 following and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 2 following and 1 following) as min1, + max(b) over (order by pk range between 2 following and 1 following) as max1, + min(b) over (partition by a order by pk range between 2 following and 1 following) as min2, + max(b) over (partition by a order by pk range between 2 following and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 preceding and 2 preceding) as min1, + max(b) over (order by pk rows between 1 preceding and 2 preceding) as max1, + min(b) over (partition by a order by pk rows between 1 preceding and 2 preceding) as min2, + max(b) over (partition by a order by pk rows between 1 preceding and 2 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 preceding and 2 preceding) as min1, + max(b) over (order by pk range between 1 preceding and 2 preceding) as max1, + min(b) over (partition by a order by pk range between 1 preceding and 2 preceding) as min2, + max(b) over (partition by a order by pk range between 1 preceding and 2 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 following and 0 following) as min1, + max(b) over (order by pk rows between 1 following and 0 following) as max1, + min(b) over (partition by a order by pk rows between 1 following and 0 following) as min2, + max(b) over (partition by a order by pk rows between 1 following and 0 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 following and 0 following) as min1, + max(b) over (order by pk range between 1 following and 0 following) as max1, + min(b) over (partition by a order by pk range between 1 following and 0 following) as min2, + max(b) over (partition by a order by pk range between 1 following and 0 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 following and 0 preceding) as min1, + max(b) over (order by pk rows between 1 following and 0 preceding) as max1, + min(b) over (partition by a order by pk rows between 1 following and 0 preceding) as min2, + max(b) over (partition by a order by pk rows between 1 following and 0 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 following and 0 preceding) as min1, + max(b) over (order by pk range between 1 following and 0 preceding) as max1, + min(b) over (partition by a order by pk range between 1 following and 0 preceding) as min2, + max(b) over (partition by a order by pk range between 1 following and 0 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 0 following and 1 preceding) as min1, + max(b) over (order by pk rows between 0 following and 1 preceding) as max1, + min(b) over (partition by a order by pk rows between 0 following and 1 preceding) as min2, + max(b) over (partition by a order by pk rows between 0 following and 1 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 0 following and 1 preceding) as min1, + max(b) over (order by pk range between 0 following and 1 preceding) as max1, + min(b) over (partition by a order by pk range between 0 following and 1 preceding) as min2, + max(b) over (partition by a order by pk range between 0 following and 1 preceding) as max2 +from t2; + +--echo # 1 row frame. +select pk, a, b, c, + min(b) over (order by pk rows between current row and current row) as min1, + max(b) over (order by pk rows between current row and current row) as max1, + min(b) over (partition by a order by pk rows between current row and current row) as min2, + max(b) over (partition by a order by pk rows between current row and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 0 preceding and current row) as min1, + max(b) over (order by pk rows between 0 preceding and current row) as max1, + min(b) over (partition by a order by pk rows between 0 preceding and current row) as min2, + max(b) over (partition by a order by pk rows between 0 preceding and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 0 preceding and 0 preceding) as min1, + max(b) over (order by pk rows between 0 preceding and 0 preceding) as max1, + min(b) over (partition by a order by pk rows between 0 preceding and 0 preceding) as min2, + max(b) over (partition by a order by pk rows between 0 preceding and 0 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 preceding and 1 preceding) as min1, + max(b) over (order by pk rows between 1 preceding and 1 preceding) as max1, + min(b) over (partition by a order by pk rows between 1 preceding and 1 preceding) as min2, + max(b) over (partition by a order by pk rows between 1 preceding and 1 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 following and 1 following) as min1, + max(b) over (order by pk rows between 1 following and 1 following) as max1, + min(b) over (partition by a order by pk rows between 1 following and 1 following) as min2, + max(b) over (partition by a order by pk rows between 1 following and 1 following) as max2 +from t2; + +--echo # Try a larger offset. +select pk, a, b, c, + min(b) over (order by pk rows between 3 following and 3 following) as min1, + max(b) over (order by pk rows between 3 following and 3 following) as max1, + min(b) over (partition by a order by pk rows between 3 following and 3 following) as min2, + max(b) over (partition by a order by pk rows between 3 following and 3 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 3 preceding and 3 preceding) as min1, + max(b) over (order by pk rows between 3 preceding and 3 preceding) as max1, + min(b) over (partition by a order by pk rows between 3 preceding and 3 preceding) as min2, + max(b) over (partition by a order by pk rows between 3 preceding and 3 preceding) as max2 +from t2; + +--echo # 2 row frame. +select pk, a, b, c, + min(b) over (order by pk rows between current row and 1 following) as min1, + max(b) over (order by pk rows between current row and 1 following) as max1, + min(b) over (partition by a order by pk rows between current row and 1 following) as min2, + max(b) over (partition by a order by pk rows between current row and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 0 preceding and 1 following) as min1, + max(b) over (order by pk rows between 0 preceding and 1 following) as max1, + min(b) over (partition by a order by pk rows between 0 preceding and 1 following) as min2, + max(b) over (partition by a order by pk rows between 0 preceding and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 preceding and current row) as min1, + max(b) over (order by pk rows between 1 preceding and current row) as max1, + min(b) over (partition by a order by pk rows between 1 preceding and current row) as min2, + max(b) over (partition by a order by pk rows between 1 preceding and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 1 preceding and 0 preceding) as min1, + max(b) over (order by pk rows between 1 preceding and 0 preceding) as max1, + min(b) over (partition by a order by pk rows between 1 preceding and 0 preceding) as min2, + max(b) over (partition by a order by pk rows between 1 preceding and 0 preceding) as max2 +from t2; + +--echo # Try a larger frame/offset. +select pk, a, b, c, + min(b) over (order by pk rows between current row and 3 following) as min1, + max(b) over (order by pk rows between current row and 3 following) as max1, + min(b) over (partition by a order by pk rows between current row and 3 following) as min2, + max(b) over (partition by a order by pk rows between current row and 3 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 2 preceding and 1 following) as min1, + max(b) over (order by pk rows between 2 preceding and 1 following) as max1, + min(b) over (partition by a order by pk rows between 2 preceding and 1 following) as min2, + max(b) over (partition by a order by pk rows between 2 preceding and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 3 preceding and current row) as min1, + max(b) over (order by pk rows between 3 preceding and current row) as max1, + min(b) over (partition by a order by pk rows between 3 preceding and current row) as min2, + max(b) over (partition by a order by pk rows between 3 preceding and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk rows between 3 preceding and 0 preceding) as min1, + max(b) over (order by pk rows between 3 preceding and 0 preceding) as max1, + min(b) over (partition by a order by pk rows between 3 preceding and 0 preceding) as min2, + max(b) over (partition by a order by pk rows between 3 preceding and 0 preceding) as max2 +from t2; + +--echo # Check range frame bounds +select pk, a, b, c, + min(b) over (order by pk range between current row and current row) as min1, + max(b) over (order by pk range between current row and current row) as max1, + min(b) over (partition by a order by pk range between current row and current row) as min2, + max(b) over (partition by a order by pk range between current row and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 0 preceding and current row) as min1, + max(b) over (order by pk range between 0 preceding and current row) as max1, + min(b) over (partition by a order by pk range between 0 preceding and current row) as min2, + max(b) over (partition by a order by pk range between 0 preceding and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 0 preceding and 0 preceding) as min1, + max(b) over (order by pk range between 0 preceding and 0 preceding) as max1, + min(b) over (partition by a order by pk range between 0 preceding and 0 preceding) as min2, + max(b) over (partition by a order by pk range between 0 preceding and 0 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 preceding and 1 preceding) as min1, + max(b) over (order by pk range between 1 preceding and 1 preceding) as max1, + min(b) over (partition by a order by pk range between 1 preceding and 1 preceding) as min2, + max(b) over (partition by a order by pk range between 1 preceding and 1 preceding) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 following and 1 following) as min1, + max(b) over (order by pk range between 1 following and 1 following) as max1, + min(b) over (partition by a order by pk range between 1 following and 1 following) as min2, + max(b) over (partition by a order by pk range between 1 following and 1 following) as max2 +from t2; + +--echo # Try a larger offset. +select pk, a, b, c, + min(b) over (order by pk range between 3 following and 3 following) as min1, + max(b) over (order by pk range between 3 following and 3 following) as max1, + min(b) over (partition by a order by pk range between 3 following and 3 following) as min2, + max(b) over (partition by a order by pk range between 3 following and 3 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 3 preceding and 3 preceding) as min1, + max(b) over (order by pk range between 3 preceding and 3 preceding) as max1, + min(b) over (partition by a order by pk range between 3 preceding and 3 preceding) as min2, + max(b) over (partition by a order by pk range between 3 preceding and 3 preceding) as max2 +from t2; + +--echo # 2 row frame. +select pk, a, b, c, + min(b) over (order by pk range between current row and 1 following) as min1, + max(b) over (order by pk range between current row and 1 following) as max1, + min(b) over (partition by a order by pk range between current row and 1 following) as min2, + max(b) over (partition by a order by pk range between current row and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 0 preceding and 1 following) as min1, + max(b) over (order by pk range between 0 preceding and 1 following) as max1, + min(b) over (partition by a order by pk range between 0 preceding and 1 following) as min2, + max(b) over (partition by a order by pk range between 0 preceding and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 preceding and current row) as min1, + max(b) over (order by pk range between 1 preceding and current row) as max1, + min(b) over (partition by a order by pk range between 1 preceding and current row) as min2, + max(b) over (partition by a order by pk range between 1 preceding and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 1 preceding and 0 preceding) as min1, + max(b) over (order by pk range between 1 preceding and 0 preceding) as max1, + min(b) over (partition by a order by pk range between 1 preceding and 0 preceding) as min2, + max(b) over (partition by a order by pk range between 1 preceding and 0 preceding) as max2 +from t2; + +--echo # Try a larger frame/offset. +select pk, a, b, c, + min(b) over (order by pk range between current row and 3 following) as min1, + max(b) over (order by pk range between current row and 3 following) as max1, + min(b) over (partition by a order by pk range between current row and 3 following) as min2, + max(b) over (partition by a order by pk range between current row and 3 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 2 preceding and 1 following) as min1, + max(b) over (order by pk range between 2 preceding and 1 following) as max1, + min(b) over (partition by a order by pk range between 2 preceding and 1 following) as min2, + max(b) over (partition by a order by pk range between 2 preceding and 1 following) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 3 preceding and current row) as min1, + max(b) over (order by pk range between 3 preceding and current row) as max1, + min(b) over (partition by a order by pk range between 3 preceding and current row) as min2, + max(b) over (partition by a order by pk range between 3 preceding and current row) as max2 +from t2; + +select pk, a, b, c, + min(b) over (order by pk range between 3 preceding and 0 preceding) as min1, + max(b) over (order by pk range between 3 preceding and 0 preceding) as max1, + min(b) over (partition by a order by pk range between 3 preceding and 0 preceding) as min2, + max(b) over (partition by a order by pk range between 3 preceding and 0 preceding) as max2 +from t2; + +drop table t2; +drop table t1; |