summaryrefslogtreecommitdiffstats
path: root/mysql-test/main/win_bit.result
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 18:00:34 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 18:00:34 +0000
commit3f619478f796eddbba6e39502fe941b285dd97b1 (patch)
treee2c7b5777f728320e5b5542b6213fd3591ba51e2 /mysql-test/main/win_bit.result
parentInitial commit. (diff)
downloadmariadb-3f619478f796eddbba6e39502fe941b285dd97b1.tar.xz
mariadb-3f619478f796eddbba6e39502fe941b285dd97b1.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_bit.result')
-rw-r--r--mysql-test/main/win_bit.result117
1 files changed, 117 insertions, 0 deletions
diff --git a/mysql-test/main/win_bit.result b/mysql-test/main/win_bit.result
new file mode 100644
index 00000000..ac7625be
--- /dev/null
+++ b/mysql-test/main/win_bit.result
@@ -0,0 +1,117 @@
+create table t1 (
+pk int primary key,
+a int,
+b int
+);
+create table t2 (
+pk int primary key,
+a int,
+b int
+);
+insert into t1 values
+( 1 , 0, 1),
+( 2 , 0, 2),
+( 3 , 1, 4),
+( 4 , 1, 8),
+( 5 , 2, 32),
+( 6 , 2, 64),
+( 7 , 2, 128),
+( 8 , 2, 16);
+insert into t2 values
+( 1 , 0, 2),
+( 2 , 0, 2),
+( 3 , 1, 4),
+( 4 , 1, 4),
+( 5 , 2, 16),
+( 6 , 2, 64),
+( 7 , 2, 128),
+( 8 , 2, 16);
+# Test bit functions on only one partition.
+select pk, a, b,
+bit_or(b) over (order by pk) as bit_or,
+bit_and(b) over (order by pk) as bit_and,
+bit_xor(b) over (order by pk) as bit_xor
+from t1;
+pk a b bit_or bit_and bit_xor
+1 0 1 1 1 1
+2 0 2 3 0 3
+3 1 4 7 0 7
+4 1 8 15 0 15
+5 2 32 47 0 47
+6 2 64 111 0 111
+7 2 128 239 0 239
+8 2 16 255 0 255
+select pk, a, b,
+bit_or(b) over (order by pk) as bit_or,
+bit_and(b) over (order by pk) as bit_and,
+bit_xor(b) over (order by pk) as bit_xor
+from t2;
+pk a b bit_or bit_and bit_xor
+1 0 2 2 2 2
+2 0 2 2 2 0
+3 1 4 6 0 4
+4 1 4 6 0 0
+5 2 16 22 0 16
+6 2 64 86 0 80
+7 2 128 214 0 208
+8 2 16 214 0 192
+# Test multiple partitions with bit functions.
+select pk, a, b,
+bit_or(b) over (partition by a order by pk) as bit_or,
+bit_and(b) over (partition by a order by pk) as bit_and,
+bit_xor(b) over (partition by a order by pk) as bit_xor
+from t1;
+pk a b bit_or bit_and bit_xor
+1 0 1 1 1 1
+2 0 2 3 0 3
+3 1 4 4 4 4
+4 1 8 12 0 12
+5 2 32 32 32 32
+6 2 64 96 0 96
+7 2 128 224 0 224
+8 2 16 240 0 240
+select pk, a, b,
+bit_or(b) over (partition by a order by pk) as bit_or,
+bit_and(b) over (partition by a order by pk) as bit_and,
+bit_xor(b) over (partition by a order by pk) as bit_xor
+from t2;
+pk a b bit_or bit_and bit_xor
+1 0 2 2 2 2
+2 0 2 2 2 0
+3 1 4 4 4 4
+4 1 4 4 4 0
+5 2 16 16 16 16
+6 2 64 80 0 80
+7 2 128 208 0 208
+8 2 16 208 0 192
+# Test remove function for bit functions using a sliding window.
+select pk, a, b,
+bit_or(b) over (partition by a order by pk ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) as bit_or,
+bit_and(b) over (partition by a order by pk) as bit_and,
+bit_xor(b) over (partition by a order by pk) as bit_xor
+from t1;
+pk a b bit_or bit_and bit_xor
+1 0 1 3 1 1
+2 0 2 3 0 3
+3 1 4 12 4 4
+4 1 8 12 0 12
+5 2 32 96 32 32
+6 2 64 224 0 96
+7 2 128 208 0 224
+8 2 16 144 0 240
+select pk, a, b,
+bit_or(b) over (partition by a order by pk) as bit_or,
+bit_and(b) over (partition by a order by pk) as bit_and,
+bit_xor(b) over (partition by a order by pk) as bit_xor
+from t2;
+pk a b bit_or bit_and bit_xor
+1 0 2 2 2 2
+2 0 2 2 2 0
+3 1 4 4 4 4
+4 1 4 4 4 0
+5 2 16 16 16 16
+6 2 64 80 0 80
+7 2 128 208 0 208
+8 2 16 208 0 192
+drop table t1;
+drop table t2;