ClickHouse/tests/queries/0_stateless/02815_join_algorithm_setting.sql
2024-05-06 12:25:28 +02:00

113 lines
4.2 KiB
SQL

-- Tags: use-rocksdb
DROP TABLE IF EXISTS rdb;
DROP TABLE IF EXISTS t2;
CREATE TABLE rdb ( `key` UInt32, `value` String )
ENGINE = EmbeddedRocksDB PRIMARY KEY key;
INSERT INTO rdb VALUES (1, 'a'), (2, 'b'), (3, 'c'), (4, 'd'), (5, 'e');
CREATE TABLE t2 ( `k` UInt16 ) ENGINE = TinyLog;
INSERT INTO t2 VALUES (4), (5), (6);
SELECT value == 'default' FROM system.settings WHERE name = 'join_algorithm';
SELECT countIf(explain like '%Algorithm: DirectKeyValueJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN PLAN actions = 1
SELECT * FROM ( SELECT k AS key FROM t2 ) AS t2
INNER JOIN rdb ON rdb.key = t2.key
ORDER BY key ASC
);
SET join_algorithm = 'direct, hash';
SELECT value == 'direct,hash' FROM system.settings WHERE name = 'join_algorithm';
SELECT countIf(explain like '%Algorithm: DirectKeyValueJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN PLAN actions = 1
SELECT * FROM ( SELECT k AS key FROM t2 ) AS t2
INNER JOIN rdb ON rdb.key = t2.key
ORDER BY key ASC
);
SET join_algorithm = 'hash, direct';
SELECT value == 'hash,direct' FROM system.settings WHERE name = 'join_algorithm';
SELECT countIf(explain like '%Algorithm: DirectKeyValueJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN PLAN actions = 1
SELECT * FROM ( SELECT k AS key FROM t2 ) AS t2
INNER JOIN rdb ON rdb.key = t2.key
ORDER BY key ASC
);
SET join_algorithm = 'grace_hash,hash';
SELECT value == 'grace_hash,hash' FROM system.settings WHERE name = 'join_algorithm';
SELECT countIf(explain like '%Algorithm: GraceHashJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN PLAN actions = 1
SELECT * FROM ( SELECT number AS key, number * 10 AS key2 FROM numbers_mt(10) ) AS t1
JOIN ( SELECT k AS key, k + 100 AS key2 FROM t2 ) AS t2 ON t1.key = t2.key OR t1.key2 = t2.key2
);
SELECT countIf(explain like '%Algorithm: GraceHashJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN PLAN actions = 1
SELECT * FROM ( SELECT number AS key, number * 10 AS key2 FROM numbers_mt(10) ) AS t1
JOIN ( SELECT k AS key, k + 100 AS key2 FROM t2 ) AS t2 ON t1.key = t2.key
);
SET join_algorithm = 'grace_hash, hash, auto';
SELECT value = 'grace_hash,hash,auto' FROM system.settings WHERE name = 'join_algorithm';
DROP DICTIONARY IF EXISTS dict;
DROP TABLE IF EXISTS src;
CREATE TABLE src (id UInt64, s String) ENGINE = MergeTree ORDER BY id
AS SELECT number, toString(number) FROM numbers(1000000);
CREATE DICTIONARY dict(
id UInt64,
s String
) PRIMARY KEY id
SOURCE(CLICKHOUSE(TABLE 'src' DB currentDatabase()))
LIFETIME (MIN 0 MAX 0)
LAYOUT(HASHED());
SET join_algorithm = 'default';
SELECT countIf(explain like '%Algorithm: DirectKeyValueJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN actions = 1
SELECT s FROM (SELECT toUInt64(9911) id) t1 INNER JOIN dict t2 USING (id)
);
SET join_algorithm = 'direct,hash';
SELECT countIf(explain like '%Algorithm: DirectKeyValueJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN actions = 1
SELECT s FROM (SELECT toUInt64(9911) id) t1 INNER JOIN dict t2 USING (id)
);
SET join_algorithm = 'hash,direct';
SELECT countIf(explain like '%Algorithm: DirectKeyValueJoin%'), countIf(explain like '%Algorithm: HashJoin%') FROM (
EXPLAIN actions = 1
SELECT s FROM (SELECT toUInt64(9911) id) t1 INNER JOIN dict t2 USING (id)
);
SET join_algorithm = 'grace_hash';
-- Cannot execute the grace hash with OR condition
SELECT * FROM ( SELECT number AS key, number * 10 AS key2 FROM numbers_mt(10) ) AS t1
JOIN ( SELECT k AS key, k + 100 AS key2 FROM t2 ) AS t2 ON t1.key = t2.key OR t1.key2 = t2.key2; -- { serverError NOT_IMPLEMENTED }
-- But for CROSS choose `hash` algorithm even though it's not enabled
SELECT * FROM ( SELECT number AS key, number * 10 AS key2 FROM numbers_mt(10) ) AS t1
CROSS JOIN ( SELECT k AS key, k + 100 AS key2 FROM t2 ) AS t2 FORMAT Null
SETTINGS allow_experimental_analyzer = 1;
-- ... (not for old analyzer)
SELECT * FROM ( SELECT number AS key, number * 10 AS key2 FROM numbers_mt(10) ) AS t1
CROSS JOIN ( SELECT k AS key, k + 100 AS key2 FROM t2 ) AS t2 FORMAT Null
SETTINGS allow_experimental_analyzer = 0; -- { serverError NOT_IMPLEMENTED }