1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
# name: test/optimizer/union_exclude.test
# description: Test union and exclude
# group: [optimizer]
statement ok
CREATE TABLE test_df_a(number BIGINT, date VARCHAR, rn BIGINT);
statement ok
INSERT INTO test_df_a VALUES(7058,'2015-07-31',1);
statement ok
INSERT INTO test_df_a VALUES(7058,'2015-07-31',2);
statement ok
INSERT INTO test_df_a VALUES(7075,'2016-07-31',1);
statement ok
INSERT INTO test_df_a VALUES(7076,'2017-07-31',1);
statement ok
INSERT INTO test_df_a VALUES(7076,'2017-07-31',2);
statement ok
CREATE TABLE test_df_b(number BIGINT, date VARCHAR, rn BIGINT);;
statement ok
INSERT INTO test_df_b VALUES(7058,'2015-07-31',1);
statement ok
INSERT INTO test_df_b VALUES(7058,'2015-07-31',2);
statement ok
INSERT INTO test_df_b VALUES(7012,'2015-07-31',1);
statement ok
INSERT INTO test_df_b VALUES(7075,'2016-07-31',1);
statement ok
INSERT INTO test_df_b VALUES(7076,'2017-07-31',1);
query II
with t as (select * from test_df_a UNION select * from test_df_b) select * exclude rn from t order by all;
----
7012 2015-07-31
7058 2015-07-31
7058 2015-07-31
7075 2016-07-31
7076 2017-07-31
7076 2017-07-31
statement ok
create table t1 as select 1 a, range b from range(100);
statement ok
create table t2 as select 1 a, range b from range(100);
query I
select count(a) from (select * from t1 union select * from t2) t_union;
----
100
query I
select count(a) from (select * from t1 union all select * from t2) t_union;
----
200
|