2023-05-25 23:04:24 +00:00
|
|
|
-- Tags: zookeeper
|
|
|
|
|
2023-12-22 17:26:31 +00:00
|
|
|
DROP TABLE IF EXISTS join_inner_table SYNC;
|
|
|
|
|
2023-05-25 23:04:24 +00:00
|
|
|
CREATE TABLE join_inner_table
|
|
|
|
(
|
|
|
|
id UUID,
|
|
|
|
key String,
|
|
|
|
number Int64,
|
|
|
|
value1 String,
|
|
|
|
value2 String,
|
|
|
|
time Int64
|
|
|
|
)
|
|
|
|
ENGINE=ReplicatedMergeTree('/clickhouse/tables/{database}/join_inner_table', 'r1')
|
|
|
|
ORDER BY (id, number, key);
|
|
|
|
|
|
|
|
INSERT INTO join_inner_table
|
|
|
|
SELECT
|
|
|
|
'833c9e22-c245-4eb5-8745-117a9a1f26b1'::UUID as id,
|
|
|
|
rowNumberInAllBlocks()::String as key,
|
|
|
|
* FROM generateRandom('number Int64, value1 String, value2 String, time Int64', 1, 10, 2)
|
|
|
|
LIMIT 100;
|
|
|
|
|
|
|
|
SET max_parallel_replicas = 3;
|
|
|
|
SET cluster_for_parallel_replicas = 'test_cluster_one_shard_three_replicas_localhost';
|
|
|
|
SET joined_subquery_requires_alias = 0;
|
|
|
|
|
|
|
|
SELECT '=============== INNER QUERY (NO PARALLEL) ===============';
|
|
|
|
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
toUInt64(min(time)) AS start_ts
|
|
|
|
FROM join_inner_table
|
|
|
|
PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
ORDER BY key, value1, value2
|
|
|
|
LIMIT 10;
|
2024-01-22 16:09:34 +00:00
|
|
|
-- settings allow_experimental_analyzer=0;
|
|
|
|
|
|
|
|
-- SELECT
|
|
|
|
-- key,
|
|
|
|
-- value1,
|
|
|
|
-- value2,
|
|
|
|
-- toUInt64(min(time)) AS start_ts
|
|
|
|
-- FROM join_inner_table
|
|
|
|
-- PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
-- GROUP BY key, value1, value2
|
|
|
|
-- ORDER BY key, value1, value2
|
|
|
|
-- LIMIT 10 settings allow_experimental_analyzer=1;
|
2023-05-25 23:04:24 +00:00
|
|
|
|
|
|
|
SELECT '=============== INNER QUERY (PARALLEL) ===============';
|
|
|
|
|
|
|
|
-- Parallel inner query alone
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
toUInt64(min(time)) AS start_ts
|
|
|
|
FROM join_inner_table
|
|
|
|
PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
ORDER BY key, value1, value2
|
|
|
|
LIMIT 10
|
2024-01-22 16:09:34 +00:00
|
|
|
SETTINGS allow_experimental_parallel_reading_from_replicas = 1, allow_experimental_analyzer=0;
|
|
|
|
|
|
|
|
-- Parallel inner query alone
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
toUInt64(min(time)) AS start_ts
|
|
|
|
FROM join_inner_table
|
|
|
|
PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
ORDER BY key, value1, value2
|
|
|
|
LIMIT 10
|
|
|
|
SETTINGS allow_experimental_parallel_reading_from_replicas = 1, allow_experimental_analyzer=1;
|
2023-05-25 23:04:24 +00:00
|
|
|
|
|
|
|
SELECT '=============== QUERIES EXECUTED BY PARALLEL INNER QUERY ALONE ===============';
|
|
|
|
|
|
|
|
SYSTEM FLUSH LOGS;
|
|
|
|
-- There should be 4 queries. The main query as received by the initiator and the 3 equal queries sent to each replica
|
2024-01-22 16:09:34 +00:00
|
|
|
SELECT is_initial_query, count() as c, replaceRegexpAll(query, '_data_(\d+)_(\d+)', '_data_') as query
|
2023-05-25 23:04:24 +00:00
|
|
|
FROM system.query_log
|
|
|
|
WHERE
|
|
|
|
event_date >= yesterday()
|
|
|
|
AND type = 'QueryFinish'
|
2024-01-22 16:09:34 +00:00
|
|
|
AND initial_query_id IN
|
2023-05-25 23:04:24 +00:00
|
|
|
(
|
|
|
|
SELECT query_id
|
|
|
|
FROM system.query_log
|
|
|
|
WHERE
|
|
|
|
current_database = currentDatabase()
|
|
|
|
AND event_date >= yesterday()
|
|
|
|
AND type = 'QueryFinish'
|
|
|
|
AND query LIKE '-- Parallel inner query alone%'
|
|
|
|
)
|
|
|
|
GROUP BY is_initial_query, query
|
|
|
|
ORDER BY is_initial_query, c, query;
|
|
|
|
|
|
|
|
---- Query with JOIN
|
|
|
|
|
2023-12-22 17:26:31 +00:00
|
|
|
DROP TABLE IF EXISTS join_outer_table SYNC;
|
|
|
|
|
2023-05-25 23:04:24 +00:00
|
|
|
CREATE TABLE join_outer_table
|
|
|
|
(
|
|
|
|
id UUID,
|
|
|
|
key String,
|
|
|
|
otherValue1 String,
|
|
|
|
otherValue2 String,
|
|
|
|
time Int64
|
|
|
|
)
|
|
|
|
ENGINE = ReplicatedMergeTree('/clickhouse/tables/{database}/join_outer_table', 'r1')
|
|
|
|
ORDER BY (id, time, key);
|
|
|
|
|
|
|
|
INSERT INTO join_outer_table
|
|
|
|
SELECT
|
|
|
|
'833c9e22-c245-4eb5-8745-117a9a1f26b1'::UUID as id,
|
|
|
|
(rowNumberInAllBlocks() % 10)::String as key,
|
|
|
|
* FROM generateRandom('otherValue1 String, otherValue2 String, time Int64', 1, 10, 2)
|
|
|
|
LIMIT 100;
|
|
|
|
|
|
|
|
|
|
|
|
SELECT '=============== OUTER QUERY (NO PARALLEL) ===============';
|
|
|
|
|
|
|
|
SELECT
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
avg(count) AS avg
|
|
|
|
FROM
|
|
|
|
(
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
count() AS count
|
|
|
|
FROM join_outer_table
|
|
|
|
INNER JOIN
|
|
|
|
(
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
toUInt64(min(time)) AS start_ts
|
|
|
|
FROM join_inner_table
|
|
|
|
PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
) USING (key)
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
)
|
|
|
|
GROUP BY value1, value2
|
|
|
|
ORDER BY value1, value2;
|
|
|
|
|
|
|
|
SELECT '=============== OUTER QUERY (PARALLEL) ===============';
|
|
|
|
|
|
|
|
-- Parallel full query
|
|
|
|
SELECT
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
avg(count) AS avg
|
|
|
|
FROM
|
|
|
|
(
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
count() AS count
|
|
|
|
FROM join_outer_table
|
|
|
|
INNER JOIN
|
|
|
|
(
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
toUInt64(min(time)) AS start_ts
|
|
|
|
FROM join_inner_table
|
|
|
|
PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
) USING (key)
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
)
|
|
|
|
GROUP BY value1, value2
|
|
|
|
ORDER BY value1, value2
|
2024-01-22 16:09:34 +00:00
|
|
|
SETTINGS allow_experimental_parallel_reading_from_replicas = 1, allow_experimental_analyzer=0;
|
|
|
|
|
|
|
|
-- Parallel full query
|
|
|
|
SELECT
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
avg(count) AS avg
|
|
|
|
FROM
|
|
|
|
(
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
count() AS count
|
|
|
|
FROM join_outer_table
|
|
|
|
INNER JOIN
|
|
|
|
(
|
|
|
|
SELECT
|
|
|
|
key,
|
|
|
|
value1,
|
|
|
|
value2,
|
|
|
|
toUInt64(min(time)) AS start_ts
|
|
|
|
FROM join_inner_table
|
|
|
|
PREWHERE (id = '833c9e22-c245-4eb5-8745-117a9a1f26b1') AND (number > toUInt64('1610517366120'))
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
) USING (key)
|
|
|
|
GROUP BY key, value1, value2
|
|
|
|
)
|
|
|
|
GROUP BY value1, value2
|
|
|
|
ORDER BY value1, value2
|
|
|
|
SETTINGS allow_experimental_parallel_reading_from_replicas = 1, allow_experimental_analyzer=1;
|
2023-05-25 23:04:24 +00:00
|
|
|
|
|
|
|
SYSTEM FLUSH LOGS;
|
|
|
|
|
|
|
|
-- There should be 7 queries. The main query as received by the initiator, the 3 equal queries to execute the subquery
|
|
|
|
-- in the inner join and the 3 queries executing the whole query (but replacing the subquery with a temp table)
|
2024-01-22 16:09:34 +00:00
|
|
|
SELECT is_initial_query, count() as c, replaceRegexpAll(query, '_data_(\d+)_(\d+)', '_data_') as query
|
2023-05-25 23:04:24 +00:00
|
|
|
FROM system.query_log
|
|
|
|
WHERE
|
|
|
|
event_date >= yesterday()
|
|
|
|
AND type = 'QueryFinish'
|
2024-01-22 16:09:34 +00:00
|
|
|
AND initial_query_id IN
|
2023-05-25 23:04:24 +00:00
|
|
|
(
|
|
|
|
SELECT query_id
|
|
|
|
FROM system.query_log
|
|
|
|
WHERE
|
|
|
|
current_database = currentDatabase()
|
|
|
|
AND event_date >= yesterday()
|
|
|
|
AND type = 'QueryFinish'
|
|
|
|
AND query LIKE '-- Parallel full query%'
|
|
|
|
)
|
|
|
|
GROUP BY is_initial_query, query
|
|
|
|
ORDER BY is_initial_query, c, query;
|