mirror of
https://github.com/apache/impala.git
synced 2026-01-02 12:00:33 -05:00
This is the first set of changes required to start getting our functional test infrastructure moved from JUnit to Python. After investigating a number of option, I decided to go with a python test executor named py.test (http://pytest.org/). It is very flexible, open source (MIT licensed), and will enable us to do some cool things like parallel test execution. As part of this change, we now use our "test vectors" for query test execution. This will be very nice because it means if load the "core" dataset you know you will be able to run the "core" query tests (specified by --exploration_strategy when running the tests). You will see that now each combination of table format + query exec options is treated like an individual test case. this will make it much easier to debug exactly where something failed. These new tests can be run using the script at tests/run-tests.sh
442 lines
15 KiB
Plaintext
442 lines
15 KiB
Plaintext
====
|
|
---- QUERY
|
|
# join cols aren't part of select list (and still get materialized)
|
|
select j.test_name, d.name
|
|
from JoinTbl j inner join DimTbl d on (j.test_id = d.id)
|
|
---- TYPES
|
|
string, string
|
|
---- RESULTS
|
|
'Name1','Name1'
|
|
'Name16','Name6'
|
|
'Name16','Name6'
|
|
'Name16','Name6'
|
|
'Name16','Name6'
|
|
'Name2','Name2'
|
|
'Name3','Name3'
|
|
'Name4','Name4'
|
|
'Name5','Name5'
|
|
'Name6','Name6'
|
|
'Name6','Name6'
|
|
====
|
|
---- QUERY
|
|
# join on bigint
|
|
select j.*, d.*
|
|
from JoinTbl j inner join DimTbl d on (j.test_id = d.id)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name16',94612,15000,1006,'Name6',94613
|
|
1006,'Name16',94612,5000,1006,'Name6',94613
|
|
1006,'Name16',94616,15000,1006,'Name6',94613
|
|
1006,'Name16',94616,5000,1006,'Name6',94613
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j left outer join DimTbl d on (j.test_id = d.id)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name16',94612,15000,1006,'Name6',94613
|
|
1006,'Name16',94612,5000,1006,'Name6',94613
|
|
1006,'Name16',94616,15000,1006,'Name6',94613
|
|
1006,'Name16',94616,5000,1006,'Name6',94613
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
1106,'Name16',94612,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94612,5000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,15000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name6',94616,5000,NULL,'NULL',NULL
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j right outer join DimTbl d on (j.test_id = d.id)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name16',94612,15000,1006,'Name6',94613
|
|
1006,'Name16',94612,5000,1006,'Name6',94613
|
|
1006,'Name16',94616,15000,1006,'Name6',94613
|
|
1006,'Name16',94616,5000,1006,'Name6',94613
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
NULL,'NULL',NULL,NULL,1007,'Name7',94614
|
|
NULL,'NULL',NULL,NULL,1008,'Name8',94614
|
|
NULL,'NULL',NULL,NULL,1009,'Name9',94615
|
|
NULL,'NULL',NULL,NULL,1010,'Name10',94615
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j full outer join DimTbl d on (j.test_id = d.id)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name16',94612,15000,1006,'Name6',94613
|
|
1006,'Name16',94612,5000,1006,'Name6',94613
|
|
1006,'Name16',94616,15000,1006,'Name6',94613
|
|
1006,'Name16',94616,5000,1006,'Name6',94613
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
1106,'Name16',94612,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94612,5000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,15000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name6',94616,5000,NULL,'NULL',NULL
|
|
NULL,'NULL',NULL,NULL,1007,'Name7',94614
|
|
NULL,'NULL',NULL,NULL,1008,'Name8',94614
|
|
NULL,'NULL',NULL,NULL,1009,'Name9',94615
|
|
NULL,'NULL',NULL,NULL,1010,'Name10',94615
|
|
====
|
|
---- QUERY
|
|
# join on string
|
|
select j.*, d.*
|
|
from JoinTbl j inner join DimTbl d on (j.test_name = d.name)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
1106,'Name6',94612,15000,1006,'Name6',94613
|
|
1106,'Name6',94612,5000,1006,'Name6',94613
|
|
1106,'Name6',94616,15000,1006,'Name6',94613
|
|
1106,'Name6',94616,5000,1006,'Name6',94613
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j left outer join DimTbl d on (j.test_name = d.name)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name16',94612,15000,NULL,'NULL',NULL
|
|
1006,'Name16',94612,5000,NULL,'NULL',NULL
|
|
1006,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1006,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
1106,'Name16',94612,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94612,5000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,15000,1006,'Name6',94613
|
|
1106,'Name6',94612,5000,1006,'Name6',94613
|
|
1106,'Name6',94616,15000,1006,'Name6',94613
|
|
1106,'Name6',94616,5000,1006,'Name6',94613
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j right outer join DimTbl d on (j.test_name = d.name)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
1106,'Name6',94612,15000,1006,'Name6',94613
|
|
1106,'Name6',94612,5000,1006,'Name6',94613
|
|
1106,'Name6',94616,15000,1006,'Name6',94613
|
|
1106,'Name6',94616,5000,1006,'Name6',94613
|
|
NULL,'NULL',NULL,NULL,1007,'Name7',94614
|
|
NULL,'NULL',NULL,NULL,1008,'Name8',94614
|
|
NULL,'NULL',NULL,NULL,1009,'Name9',94615
|
|
NULL,'NULL',NULL,NULL,1010,'Name10',94615
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j full outer join DimTbl d on (j.test_name = d.name)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1003,'Name3',94612
|
|
1004,'Name4',94611,5000,1004,'Name4',94612
|
|
1005,'Name5',94611,5000,1005,'Name5',94613
|
|
1006,'Name16',94612,15000,NULL,'NULL',NULL
|
|
1006,'Name16',94612,5000,NULL,'NULL',NULL
|
|
1006,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1006,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1006,'Name6',94616,15000,1006,'Name6',94613
|
|
1006,'Name6',94616,5000,1006,'Name6',94613
|
|
1106,'Name16',94612,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94612,5000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,15000,1006,'Name6',94613
|
|
1106,'Name6',94612,5000,1006,'Name6',94613
|
|
1106,'Name6',94616,15000,1006,'Name6',94613
|
|
1106,'Name6',94616,5000,1006,'Name6',94613
|
|
NULL,'NULL',NULL,NULL,1007,'Name7',94614
|
|
NULL,'NULL',NULL,NULL,1008,'Name8',94614
|
|
NULL,'NULL',NULL,NULL,1009,'Name9',94615
|
|
NULL,'NULL',NULL,NULL,1010,'Name10',94615
|
|
====
|
|
---- QUERY
|
|
# join on int
|
|
select j.*, d.*
|
|
from JoinTbl j inner join DimTbl d on (j.test_zip = d.zip)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1001,'Name1',94611,5000,1002,'Name2',94611
|
|
1002,'Name2',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1001,'Name1',94611
|
|
1003,'Name3',94611,5000,1002,'Name2',94611
|
|
1004,'Name4',94611,5000,1001,'Name1',94611
|
|
1004,'Name4',94611,5000,1002,'Name2',94611
|
|
1005,'Name5',94611,5000,1001,'Name1',94611
|
|
1005,'Name5',94611,5000,1002,'Name2',94611
|
|
1006,'Name16',94612,15000,1003,'Name3',94612
|
|
1006,'Name16',94612,15000,1004,'Name4',94612
|
|
1006,'Name16',94612,5000,1003,'Name3',94612
|
|
1006,'Name16',94612,5000,1004,'Name4',94612
|
|
1106,'Name16',94612,15000,1003,'Name3',94612
|
|
1106,'Name16',94612,15000,1004,'Name4',94612
|
|
1106,'Name16',94612,5000,1003,'Name3',94612
|
|
1106,'Name16',94612,5000,1004,'Name4',94612
|
|
1106,'Name6',94612,15000,1003,'Name3',94612
|
|
1106,'Name6',94612,15000,1004,'Name4',94612
|
|
1106,'Name6',94612,5000,1003,'Name3',94612
|
|
1106,'Name6',94612,5000,1004,'Name4',94612
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j left outer join DimTbl d on (j.test_zip = d.zip)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1001,'Name1',94611,5000,1002,'Name2',94611
|
|
1002,'Name2',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1001,'Name1',94611
|
|
1003,'Name3',94611,5000,1002,'Name2',94611
|
|
1004,'Name4',94611,5000,1001,'Name1',94611
|
|
1004,'Name4',94611,5000,1002,'Name2',94611
|
|
1005,'Name5',94611,5000,1001,'Name1',94611
|
|
1005,'Name5',94611,5000,1002,'Name2',94611
|
|
1006,'Name16',94612,15000,1003,'Name3',94612
|
|
1006,'Name16',94612,15000,1004,'Name4',94612
|
|
1006,'Name16',94612,5000,1003,'Name3',94612
|
|
1006,'Name16',94612,5000,1004,'Name4',94612
|
|
1006,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1006,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1006,'Name6',94616,15000,NULL,'NULL',NULL
|
|
1006,'Name6',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name16',94612,15000,1003,'Name3',94612
|
|
1106,'Name16',94612,15000,1004,'Name4',94612
|
|
1106,'Name16',94612,5000,1003,'Name3',94612
|
|
1106,'Name16',94612,5000,1004,'Name4',94612
|
|
1106,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,15000,1003,'Name3',94612
|
|
1106,'Name6',94612,15000,1004,'Name4',94612
|
|
1106,'Name6',94612,5000,1003,'Name3',94612
|
|
1106,'Name6',94612,5000,1004,'Name4',94612
|
|
1106,'Name6',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name6',94616,5000,NULL,'NULL',NULL
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j right outer join DimTbl d on (j.test_zip = d.zip)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1001,'Name1',94611,5000,1002,'Name2',94611
|
|
1002,'Name2',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1001,'Name1',94611
|
|
1003,'Name3',94611,5000,1002,'Name2',94611
|
|
1004,'Name4',94611,5000,1001,'Name1',94611
|
|
1004,'Name4',94611,5000,1002,'Name2',94611
|
|
1005,'Name5',94611,5000,1001,'Name1',94611
|
|
1005,'Name5',94611,5000,1002,'Name2',94611
|
|
1006,'Name16',94612,15000,1003,'Name3',94612
|
|
1006,'Name16',94612,15000,1004,'Name4',94612
|
|
1006,'Name16',94612,5000,1003,'Name3',94612
|
|
1006,'Name16',94612,5000,1004,'Name4',94612
|
|
1106,'Name16',94612,15000,1003,'Name3',94612
|
|
1106,'Name16',94612,15000,1004,'Name4',94612
|
|
1106,'Name16',94612,5000,1003,'Name3',94612
|
|
1106,'Name16',94612,5000,1004,'Name4',94612
|
|
1106,'Name6',94612,15000,1003,'Name3',94612
|
|
1106,'Name6',94612,15000,1004,'Name4',94612
|
|
1106,'Name6',94612,5000,1003,'Name3',94612
|
|
1106,'Name6',94612,5000,1004,'Name4',94612
|
|
NULL,'NULL',NULL,NULL,1005,'Name5',94613
|
|
NULL,'NULL',NULL,NULL,1006,'Name6',94613
|
|
NULL,'NULL',NULL,NULL,1007,'Name7',94614
|
|
NULL,'NULL',NULL,NULL,1008,'Name8',94614
|
|
NULL,'NULL',NULL,NULL,1009,'Name9',94615
|
|
NULL,'NULL',NULL,NULL,1010,'Name10',94615
|
|
====
|
|
---- QUERY
|
|
select j.*, d.*
|
|
from JoinTbl j full outer join DimTbl d on (j.test_zip = d.zip)
|
|
---- TYPES
|
|
bigint, string, int, int, bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611,5000,1001,'Name1',94611
|
|
1001,'Name1',94611,5000,1002,'Name2',94611
|
|
1002,'Name2',94611,5000,1001,'Name1',94611
|
|
1002,'Name2',94611,5000,1002,'Name2',94611
|
|
1003,'Name3',94611,5000,1001,'Name1',94611
|
|
1003,'Name3',94611,5000,1002,'Name2',94611
|
|
1004,'Name4',94611,5000,1001,'Name1',94611
|
|
1004,'Name4',94611,5000,1002,'Name2',94611
|
|
1005,'Name5',94611,5000,1001,'Name1',94611
|
|
1005,'Name5',94611,5000,1002,'Name2',94611
|
|
1006,'Name16',94612,15000,1003,'Name3',94612
|
|
1006,'Name16',94612,15000,1004,'Name4',94612
|
|
1006,'Name16',94612,5000,1003,'Name3',94612
|
|
1006,'Name16',94612,5000,1004,'Name4',94612
|
|
1006,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1006,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1006,'Name6',94616,15000,NULL,'NULL',NULL
|
|
1006,'Name6',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name16',94612,15000,1003,'Name3',94612
|
|
1106,'Name16',94612,15000,1004,'Name4',94612
|
|
1106,'Name16',94612,5000,1003,'Name3',94612
|
|
1106,'Name16',94612,5000,1004,'Name4',94612
|
|
1106,'Name16',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name16',94616,5000,NULL,'NULL',NULL
|
|
1106,'Name6',94612,15000,1003,'Name3',94612
|
|
1106,'Name6',94612,15000,1004,'Name4',94612
|
|
1106,'Name6',94612,5000,1003,'Name3',94612
|
|
1106,'Name6',94612,5000,1004,'Name4',94612
|
|
1106,'Name6',94616,15000,NULL,'NULL',NULL
|
|
1106,'Name6',94616,5000,NULL,'NULL',NULL
|
|
NULL,'NULL',NULL,NULL,1005,'Name5',94613
|
|
NULL,'NULL',NULL,NULL,1006,'Name6',94613
|
|
NULL,'NULL',NULL,NULL,1007,'Name7',94614
|
|
NULL,'NULL',NULL,NULL,1008,'Name8',94614
|
|
NULL,'NULL',NULL,NULL,1009,'Name9',94615
|
|
NULL,'NULL',NULL,NULL,1010,'Name10',94615
|
|
====
|
|
---- QUERY
|
|
# semi-join on bigint
|
|
select d.*
|
|
from DimTbl d left semi join JoinTbl j on (d.id = j.test_id)
|
|
---- TYPES
|
|
bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611
|
|
1002,'Name2',94611
|
|
1003,'Name3',94612
|
|
1004,'Name4',94612
|
|
1005,'Name5',94613
|
|
1006,'Name6',94613
|
|
====
|
|
---- QUERY
|
|
# semi-join on string
|
|
select d.*
|
|
from DimTbl d left semi join JoinTbl j on (j.test_name = d.name)
|
|
---- TYPES
|
|
bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611
|
|
1002,'Name2',94611
|
|
1003,'Name3',94612
|
|
1004,'Name4',94612
|
|
1005,'Name5',94613
|
|
1006,'Name6',94613
|
|
====
|
|
---- QUERY
|
|
# semi-join on int
|
|
select d.*
|
|
from DimTbl d left semi join JoinTbl j on (j.test_zip = d.zip)
|
|
---- TYPES
|
|
bigint, string, int
|
|
---- RESULTS
|
|
1001,'Name1',94611
|
|
1002,'Name2',94611
|
|
1003,'Name3',94612
|
|
1004,'Name4',94612
|
|
====
|
|
---- QUERY
|
|
# joins on empty tables
|
|
select * from emptytable t1 full outer join emptytable t2 on (t1.field=t2.field)
|
|
---- TYPES
|
|
int, string, int, string
|
|
---- RESULTS
|
|
====
|
|
---- QUERY
|
|
select * from emptytable t1 right outer join greptiny t2 on (t1.field=t2.field)
|
|
---- TYPES
|
|
int, string, string
|
|
---- RESULTS
|
|
====
|
|
---- QUERY
|
|
select count(*) from greptiny t1 left outer join emptytable t2 on (t1.field=t2.field)
|
|
---- TYPES
|
|
bigint
|
|
---- RESULTS
|
|
100
|
|
====
|
|
---- QUERY
|
|
# test nested joins
|
|
select a.id, b.id, c.id, a.day, b.day, c.month, a.month, b.month
|
|
from alltypesagg a join alltypesagg b on
|
|
(a.id = b.id and a.month = b.day and b.month = 1 and b.month = b.day and a.day = b.day)
|
|
left outer join alltypessmall c on
|
|
(c.id = a.id and a.month = c.id and a.month=c.month)
|
|
where a.id < 10
|
|
---- TYPES
|
|
int, int, int, int, int, int, int, int
|
|
---- RESULTS
|
|
0,0,NULL,1,1,NULL,1,1
|
|
1,1,1,1,1,1,1,1
|
|
2,2,NULL,1,1,NULL,1,1
|
|
3,3,NULL,1,1,NULL,1,1
|
|
4,4,NULL,1,1,NULL,1,1
|
|
5,5,NULL,1,1,NULL,1,1
|
|
6,6,NULL,1,1,NULL,1,1
|
|
7,7,NULL,1,1,NULL,1,1
|
|
8,8,NULL,1,1,NULL,1,1
|
|
9,9,NULL,1,1,NULL,1,1
|
|
====
|