3b52f80237
differ from PG and need to be resolved. FossilOrigin-Name: befa8cbc0682bc3269f87e392a1f3d4baacf4db7c716ea84192bb9c13c99490b
2962 lines
105 KiB
Plaintext
2962 lines
105 KiB
Plaintext
# 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 " "\}"
|
|
#
|
|
# }
|
|
# }
|
|
# }
|