2022-10-25 10:35:25 +00:00
|
|
|
SET allow_experimental_analyzer = 1;
|
2022-09-28 16:25:59 +00:00
|
|
|
|
|
|
|
DROP TABLE IF EXISTS test_table_join_1;
|
|
|
|
CREATE TABLE test_table_join_1
|
|
|
|
(
|
|
|
|
id UInt8,
|
|
|
|
value String
|
|
|
|
) ENGINE = TinyLog;
|
|
|
|
|
|
|
|
DROP TABLE IF EXISTS test_table_join_2;
|
|
|
|
CREATE TABLE test_table_join_2
|
|
|
|
(
|
|
|
|
id UInt16,
|
|
|
|
value String
|
|
|
|
) ENGINE = TinyLog;
|
|
|
|
|
|
|
|
DROP TABLE IF EXISTS test_table_join_3;
|
|
|
|
CREATE TABLE test_table_join_3
|
|
|
|
(
|
|
|
|
id UInt64,
|
|
|
|
value String
|
|
|
|
) ENGINE = TinyLog;
|
|
|
|
|
|
|
|
INSERT INTO test_table_join_1 VALUES (0, 'Join_1_Value_0');
|
|
|
|
INSERT INTO test_table_join_1 VALUES (1, 'Join_1_Value_1');
|
|
|
|
INSERT INTO test_table_join_1 VALUES (2, 'Join_1_Value_2');
|
|
|
|
|
|
|
|
INSERT INTO test_table_join_2 VALUES (0, 'Join_2_Value_0');
|
|
|
|
INSERT INTO test_table_join_2 VALUES (1, 'Join_2_Value_1');
|
|
|
|
INSERT INTO test_table_join_2 VALUES (3, 'Join_2_Value_3');
|
|
|
|
|
|
|
|
INSERT INTO test_table_join_3 VALUES (0, 'Join_3_Value_0');
|
|
|
|
INSERT INTO test_table_join_3 VALUES (1, 'Join_3_Value_1');
|
|
|
|
INSERT INTO test_table_join_3 VALUES (4, 'Join_3_Value_4');
|
|
|
|
|
|
|
|
-- { echoOn }
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 INNER JOIN test_table_join_2 AS t2 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
2024-05-30 12:27:25 +00:00
|
|
|
SELECT * FROM test_table_join_1 AS t1 INNER JOIN test_table_join_2 AS t2 USING (id, id, id) ORDER BY id, t1.value; -- { serverError BAD_ARGUMENTS }
|
2022-10-11 16:54:23 +00:00
|
|
|
|
2022-09-28 16:25:59 +00:00
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 LEFT JOIN test_table_join_2 AS t2 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 RIGHT JOIN test_table_join_2 AS t2 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 FULL JOIN test_table_join_2 AS t2 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 INNER JOIN test_table_join_2 AS t2 USING (id) INNER JOIN test_table_join_3 AS t3 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 INNER JOIN test_table_join_2 AS t2 USING (id) LEFT JOIN test_table_join_3 AS t3 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 INNER JOIN test_table_join_2 AS t2 USING (id) RIGHT JOIN test_table_join_3 AS t3 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
SELECT '--';
|
|
|
|
|
|
|
|
SELECT * FROM test_table_join_1 AS t1 INNER JOIN test_table_join_2 AS t2 USING (id) FULL JOIN test_table_join_3 AS t3 USING (id) ORDER BY id, t1.value;
|
|
|
|
|
|
|
|
-- { echoOff }
|
|
|
|
|
|
|
|
DROP TABLE test_table_join_1;
|
|
|
|
DROP TABLE test_table_join_2;
|
|
|
|
DROP TABLE test_table_join_3;
|