--- /dev/null
+# 2022-05-04
+#
+# The author disclaims copyright to this source code. In place of
+# a legal notice, here is a blessing:
+#
+# May you do good and not evil.
+# May you find forgiveness for yourself and forgive others.
+# May you share freely, never taking more than you give.
+#
+#***********************************************************************
+#
+# This file implements tests for JOINs that use Bloom filters.
+#
+# The test case output is all generated by PostgreSQL 14. This test module
+# was created as follows:
+#
+# 1. Run a TCL script (included at the bottom of this file) that
+# generates an input script for "psql" that will run man
+# diverse tests on joins.
+#
+# 2. Run the script from step (1) through psql and collect the
+# output.
+#
+# 3. Make a few minor global search-and-replace operations to convert
+# the psql output into a form suitable for this test module.
+#
+# 4. Add this header, and the script content at the footer.
+#
+set testdir [file dirname $argv0]
+source $testdir/tester.tcl
+db nullvalue -
+db eval {
+ CREATE TABLE t1(a INT, b INT, c INT, d INT);
+ WITH RECURSIVE c(x) AS (VALUES(0) UNION ALL SELECT x+1 FROM c WHERE x<95)
+ INSERT INTO t1(a,b,c,d) SELECT x, x+100, x+200, x+300 FROM c;
+ CREATE TABLE t2(b INT, x INT);
+ INSERT INTO t2(b,x) SELECT b, a FROM t1 WHERE a%2=0;
+ CREATE INDEX t2b ON t2(b);
+ CREATE TABLE t3(c INT, y INT);
+ INSERT INTO t3(c,y) SELECT c, a FROM t1 WHERE a%3=0;
+ CREATE INDEX t3c ON t3(c);
+ CREATE TABLE t4(d INT, z INT);
+ INSERT INTO t4(d,z) SELECT d, a FROM t1 WHERE a%5=0;
+ CREATE INDEX t4d ON t4(d);
+ INSERT INTO t1(a,b,c,d) VALUES
+ (96,NULL,296,396),
+ (97,197,NULL,397),
+ (98,198,298,NULL),
+ (99,NULL,NULL,NULL);
+ ANALYZE;
+}
+do_execsql_test joinD-1 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-2 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-3 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-4 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-5 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-6 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+}
+do_execsql_test joinD-7 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-8 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-9 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-10 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+}
+do_execsql_test joinD-11 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-12 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-13 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-14 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+}
+do_execsql_test joinD-15 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-16 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 INNER JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-17 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-18 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+}
+do_execsql_test joinD-19 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-20 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-21 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+}
+do_execsql_test joinD-22 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+}
+do_execsql_test joinD-23 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-24 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-25 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-26 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+ - - - - - - 200 0 - -
+}
+do_execsql_test joinD-27 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-28 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+ - - - - - - 200 0 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-29 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+}
+do_execsql_test joinD-30 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - - - 200 0 - -
+}
+do_execsql_test joinD-31 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-32 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 LEFT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - - - 200 0 - -
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-33 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-34 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-35 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-36 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-37 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-38 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - 100 0 - - - -
+}
+do_execsql_test joinD-39 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-40 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - 100 0 - - - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-41 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-42 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+}
+do_execsql_test joinD-43 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 30 130 230 330 130 30 230 30 330 30
+ 60 160 260 360 160 60 260 60 360 60
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-44 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 6 106 206 306 106 6 206 6 - -
+ 12 112 212 312 112 12 212 12 - -
+ 18 118 218 318 118 18 218 18 - -
+ 24 124 224 324 124 24 224 24 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 36 136 236 336 136 36 236 36 - -
+ 42 142 242 342 142 42 242 42 - -
+ 48 148 248 348 148 48 248 48 - -
+ 54 154 254 354 154 54 254 54 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 66 166 266 366 166 66 266 66 - -
+ 72 172 272 372 172 72 272 72 - -
+ 78 178 278 378 178 78 278 78 - -
+ 84 184 284 384 184 84 284 84 - -
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 315 15
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 345 45
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 375 75
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-45 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-46 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - 100 0 - - - -
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+}
+do_execsql_test joinD-47 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 10 110 210 310 110 10 - - 310 10
+ 20 120 220 320 120 20 - - 320 20
+ 30 130 230 330 130 30 230 30 330 30
+ 40 140 240 340 140 40 - - 340 40
+ 50 150 250 350 150 50 - - 350 50
+ 60 160 260 360 160 60 260 60 360 60
+ 70 170 270 370 170 70 - - 370 70
+ 80 180 280 380 180 80 - - 380 80
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-48 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 RIGHT JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 2 102 202 302 102 2 - - - -
+ 4 104 204 304 104 4 - - - -
+ 6 106 206 306 106 6 206 6 - -
+ 8 108 208 308 108 8 - - - -
+ 10 110 210 310 110 10 - - 310 10
+ 12 112 212 312 112 12 212 12 - -
+ 14 114 214 314 114 14 - - - -
+ 16 116 216 316 116 16 - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 20 120 220 320 120 20 - - 320 20
+ 22 122 222 322 122 22 - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 26 126 226 326 126 26 - - - -
+ 28 128 228 328 128 28 - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 32 132 232 332 132 32 - - - -
+ 34 134 234 334 134 34 - - - -
+ 36 136 236 336 136 36 236 36 - -
+ 38 138 238 338 138 38 - - - -
+ 40 140 240 340 140 40 - - 340 40
+ 42 142 242 342 142 42 242 42 - -
+ 44 144 244 344 144 44 - - - -
+ 46 146 246 346 146 46 - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 50 150 250 350 150 50 - - 350 50
+ 52 152 252 352 152 52 - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 56 156 256 356 156 56 - - - -
+ 58 158 258 358 158 58 - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 62 162 262 362 162 62 - - - -
+ 64 164 264 364 164 64 - - - -
+ 66 166 266 366 166 66 266 66 - -
+ 68 168 268 368 168 68 - - - -
+ 70 170 270 370 170 70 - - 370 70
+ 72 172 272 372 172 72 272 72 - -
+ 74 174 274 374 174 74 - - - -
+ 76 176 276 376 176 76 - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 80 180 280 380 180 80 - - 380 80
+ 82 182 282 382 182 82 - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 86 186 286 386 186 86 - - - -
+ 88 188 288 388 188 88 - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 92 192 292 392 192 92 - - - -
+ 94 194 294 394 194 94 - - - -
+ - - - - 100 0 - - - -
+ - - - - - - 200 0 - -
+ - - - - - - 203 3 - -
+ - - - - - - 209 9 - -
+ - - - - - - 215 15 - -
+ - - - - - - 221 21 - -
+ - - - - - - 227 27 - -
+ - - - - - - 233 33 - -
+ - - - - - - 239 39 - -
+ - - - - - - 245 45 - -
+ - - - - - - 251 51 - -
+ - - - - - - 257 57 - -
+ - - - - - - 263 63 - -
+ - - - - - - 269 69 - -
+ - - - - - - 275 75 - -
+ - - - - - - 281 81 - -
+ - - - - - - 287 87 - -
+ - - - - - - 293 93 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 315 15
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 345 45
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 375 75
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-49 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-50 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+}
+do_execsql_test joinD-51 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-52 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ INNER JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-53 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+}
+do_execsql_test joinD-54 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - 100 0 - - - -
+}
+do_execsql_test joinD-55 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-56 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ LEFT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - 100 0 - - - -
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-57 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+}
+do_execsql_test joinD-58 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+ - - - - - - 200 0 - -
+}
+do_execsql_test joinD-59 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 15 115 215 315 - - 215 15 315 15
+ 30 130 230 330 130 30 230 30 330 30
+ 45 145 245 345 - - 245 45 345 45
+ 60 160 260 360 160 60 260 60 360 60
+ 75 175 275 375 - - 275 75 375 75
+ 90 190 290 390 190 90 290 90 390 90
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-60 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ RIGHT JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 3 103 203 303 - - 203 3 - -
+ 6 106 206 306 106 6 206 6 - -
+ 9 109 209 309 - - 209 9 - -
+ 12 112 212 312 112 12 212 12 - -
+ 15 115 215 315 - - 215 15 315 15
+ 18 118 218 318 118 18 218 18 - -
+ 21 121 221 321 - - 221 21 - -
+ 24 124 224 324 124 24 224 24 - -
+ 27 127 227 327 - - 227 27 - -
+ 30 130 230 330 130 30 230 30 330 30
+ 33 133 233 333 - - 233 33 - -
+ 36 136 236 336 136 36 236 36 - -
+ 39 139 239 339 - - 239 39 - -
+ 42 142 242 342 142 42 242 42 - -
+ 45 145 245 345 - - 245 45 345 45
+ 48 148 248 348 148 48 248 48 - -
+ 51 151 251 351 - - 251 51 - -
+ 54 154 254 354 154 54 254 54 - -
+ 57 157 257 357 - - 257 57 - -
+ 60 160 260 360 160 60 260 60 360 60
+ 63 163 263 363 - - 263 63 - -
+ 66 166 266 366 166 66 266 66 - -
+ 69 169 269 369 - - 269 69 - -
+ 72 172 272 372 172 72 272 72 - -
+ 75 175 275 375 - - 275 75 375 75
+ 78 178 278 378 178 78 278 78 - -
+ 81 181 281 381 - - 281 81 - -
+ 84 184 284 384 184 84 284 84 - -
+ 87 187 287 387 - - 287 87 - -
+ 90 190 290 390 190 90 290 90 390 90
+ 93 193 293 393 - - 293 93 - -
+ - - - - - - 200 0 - -
+ - - - - - - - - 300 0
+ - - - - - - - - 305 5
+ - - - - - - - - 310 10
+ - - - - - - - - 320 20
+ - - - - - - - - 325 25
+ - - - - - - - - 335 35
+ - - - - - - - - 340 40
+ - - - - - - - - 350 50
+ - - - - - - - - 355 55
+ - - - - - - - - 365 65
+ - - - - - - - - 370 70
+ - - - - - - - - 380 80
+ - - - - - - - - 385 85
+ - - - - - - - - 395 95
+}
+do_execsql_test joinD-61 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ INNER JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+}
+do_execsql_test joinD-62 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ LEFT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - 100 0 - - - -
+ - - - - - - 200 0 - -
+}
+do_execsql_test joinD-63 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ RIGHT JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 5 105 205 305 - - - - 305 5
+ 10 110 210 310 110 10 - - 310 10
+ 15 115 215 315 - - 215 15 315 15
+ 20 120 220 320 120 20 - - 320 20
+ 25 125 225 325 - - - - 325 25
+ 30 130 230 330 130 30 230 30 330 30
+ 35 135 235 335 - - - - 335 35
+ 40 140 240 340 140 40 - - 340 40
+ 45 145 245 345 - - 245 45 345 45
+ 50 150 250 350 150 50 - - 350 50
+ 55 155 255 355 - - - - 355 55
+ 60 160 260 360 160 60 260 60 360 60
+ 65 165 265 365 - - - - 365 65
+ 70 170 270 370 170 70 - - 370 70
+ 75 175 275 375 - - 275 75 375 75
+ 80 180 280 380 180 80 - - 380 80
+ 85 185 285 385 - - - - 385 85
+ 90 190 290 390 190 90 290 90 390 90
+ 95 195 295 395 - - - - 395 95
+ - - - - - - - - 300 0
+}
+do_execsql_test joinD-64 {
+ SELECT t1.*, t2.*, t3.*, t4.*
+ FROM t1 FULL JOIN t2 ON t1.b=t2.b AND t2.x>0
+ FULL JOIN t3 ON t1.c=t3.c AND t3.y>0
+ FULL JOIN t4 ON t1.d=t4.d AND t4.z>0
+ ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);
+} {
+ 0 100 200 300 - - - - - -
+ 1 101 201 301 - - - - - -
+ 2 102 202 302 102 2 - - - -
+ 3 103 203 303 - - 203 3 - -
+ 4 104 204 304 104 4 - - - -
+ 5 105 205 305 - - - - 305 5
+ 6 106 206 306 106 6 206 6 - -
+ 7 107 207 307 - - - - - -
+ 8 108 208 308 108 8 - - - -
+ 9 109 209 309 - - 209 9 - -
+ 10 110 210 310 110 10 - - 310 10
+ 11 111 211 311 - - - - - -
+ 12 112 212 312 112 12 212 12 - -
+ 13 113 213 313 - - - - - -
+ 14 114 214 314 114 14 - - - -
+ 15 115 215 315 - - 215 15 315 15
+ 16 116 216 316 116 16 - - - -
+ 17 117 217 317 - - - - - -
+ 18 118 218 318 118 18 218 18 - -
+ 19 119 219 319 - - - - - -
+ 20 120 220 320 120 20 - - 320 20
+ 21 121 221 321 - - 221 21 - -
+ 22 122 222 322 122 22 - - - -
+ 23 123 223 323 - - - - - -
+ 24 124 224 324 124 24 224 24 - -
+ 25 125 225 325 - - - - 325 25
+ 26 126 226 326 126 26 - - - -
+ 27 127 227 327 - - 227 27 - -
+ 28 128 228 328 128 28 - - - -
+ 29 129 229 329 - - - - - -
+ 30 130 230 330 130 30 230 30 330 30
+ 31 131 231 331 - - - - - -
+ 32 132 232 332 132 32 - - - -
+ 33 133 233 333 - - 233 33 - -
+ 34 134 234 334 134 34 - - - -
+ 35 135 235 335 - - - - 335 35
+ 36 136 236 336 136 36 236 36 - -
+ 37 137 237 337 - - - - - -
+ 38 138 238 338 138 38 - - - -
+ 39 139 239 339 - - 239 39 - -
+ 40 140 240 340 140 40 - - 340 40
+ 41 141 241 341 - - - - - -
+ 42 142 242 342 142 42 242 42 - -
+ 43 143 243 343 - - - - - -
+ 44 144 244 344 144 44 - - - -
+ 45 145 245 345 - - 245 45 345 45
+ 46 146 246 346 146 46 - - - -
+ 47 147 247 347 - - - - - -
+ 48 148 248 348 148 48 248 48 - -
+ 49 149 249 349 - - - - - -
+ 50 150 250 350 150 50 - - 350 50
+ 51 151 251 351 - - 251 51 - -
+ 52 152 252 352 152 52 - - - -
+ 53 153 253 353 - - - - - -
+ 54 154 254 354 154 54 254 54 - -
+ 55 155 255 355 - - - - 355 55
+ 56 156 256 356 156 56 - - - -
+ 57 157 257 357 - - 257 57 - -
+ 58 158 258 358 158 58 - - - -
+ 59 159 259 359 - - - - - -
+ 60 160 260 360 160 60 260 60 360 60
+ 61 161 261 361 - - - - - -
+ 62 162 262 362 162 62 - - - -
+ 63 163 263 363 - - 263 63 - -
+ 64 164 264 364 164 64 - - - -
+ 65 165 265 365 - - - - 365 65
+ 66 166 266 366 166 66 266 66 - -
+ 67 167 267 367 - - - - - -
+ 68 168 268 368 168 68 - - - -
+ 69 169 269 369 - - 269 69 - -
+ 70 170 270 370 170 70 - - 370 70
+ 71 171 271 371 - - - - - -
+ 72 172 272 372 172 72 272 72 - -
+ 73 173 273 373 - - - - - -
+ 74 174 274 374 174 74 - - - -
+ 75 175 275 375 - - 275 75 375 75
+ 76 176 276 376 176 76 - - - -
+ 77 177 277 377 - - - - - -
+ 78 178 278 378 178 78 278 78 - -
+ 79 179 279 379 - - - - - -
+ 80 180 280 380 180 80 - - 380 80
+ 81 181 281 381 - - 281 81 - -
+ 82 182 282 382 182 82 - - - -
+ 83 183 283 383 - - - - - -
+ 84 184 284 384 184 84 284 84 - -
+ 85 185 285 385 - - - - 385 85
+ 86 186 286 386 186 86 - - - -
+ 87 187 287 387 - - 287 87 - -
+ 88 188 288 388 188 88 - - - -
+ 89 189 289 389 - - - - - -
+ 90 190 290 390 190 90 290 90 390 90
+ 91 191 291 391 - - - - - -
+ 92 192 292 392 192 92 - - - -
+ 93 193 293 393 - - 293 93 - -
+ 94 194 294 394 194 94 - - - -
+ 95 195 295 395 - - - - 395 95
+ 96 - 296 396 - - - - - -
+ 97 197 - 397 - - - - - -
+ 98 198 298 - - - - - - -
+ 99 - - - - - - - - -
+ - - - - 100 0 - - - -
+ - - - - - - 200 0 - -
+ - - - - - - - - 300 0
+}
+finish_test
+#############################################################################
+# This is the TCL script used to generate the psql script that generated
+# the data above.
+#
+# puts "
+# \\pset border off
+# \\pset tuples_only on
+# \\pset null -
+#
+# DROP TABLE IF EXISTS t1;
+# DROP TABLE IF EXISTS t2;
+# DROP TABLE IF EXISTS t3;
+# DROP TABLE IF EXISTS t4;
+# CREATE TABLE t1(a INT, b INT, c INT, d INT);
+# WITH RECURSIVE c(x) AS (VALUES(0) UNION ALL SELECT x+1 FROM c WHERE x<95)
+# INSERT INTO t1(a,b,c,d) SELECT x, x+100, x+200, x+300 FROM c;
+# CREATE TABLE t2(b INT, x INT);
+# INSERT INTO t2(b,x) SELECT b, a FROM t1 WHERE a%2=0;
+# CREATE INDEX t2b ON t2(b);
+# CREATE TABLE t3(c INT, y INT);
+# INSERT INTO t3(c,y) SELECT c, a FROM t1 WHERE a%3=0;
+# CREATE INDEX t3c ON t3(c);
+# CREATE TABLE t4(d INT, z INT);
+# INSERT INTO t4(d,z) SELECT d, a FROM t1 WHERE a%5=0;
+# CREATE INDEX t4d ON t4(d);
+# INSERT INTO t1(a,b,c,d) VALUES
+# (96,NULL,296,396),
+# (97,197,NULL,397),
+# (98,198,298,NULL),
+# (99,NULL,NULL,NULL);
+# "
+#
+# proc echo {prefix txt} {
+# regsub -all {\n} $txt \n$prefix txt
+# puts "$prefix$txt"
+# }
+#
+# set n 0
+# set k 0
+# foreach j1 {INNER LEFT RIGHT FULL} {
+# foreach j2 {INNER LEFT RIGHT FULL} {
+# foreach j3 {INNER LEFT RIGHT FULL} {
+#
+# incr n
+# incr k
+# set q1 ""
+# append q1 "SELECT t1.*, t2.*, t3.*, t4.*\n"
+# append q1 " FROM t1 $j1 JOIN t2 ON t1.b=t2.b AND t2.x>0\n"
+# append q1 " $j2 JOIN t3 ON t1.c=t3.c AND t3.y>0\n"
+# append q1 " $j3 JOIN t4 ON t1.d=t4.d AND t4.z>0\n"
+# append q1 " ORDER BY coalesce(t1.a,t2.b,t3.c,t4.d,0);"
+#
+# echo "\\qecho " "do_execsql_test joinB-$n \{"
+# echo "\\qecho X " $q1
+# echo "\\qecho " "\} \{"
+# puts $q1
+# echo "\\qecho " "\}"
+#
+# }
+# }
+# }