ClickHouse/tests/performance/explain_ast.xml
2021-11-29 13:09:53 +01:00

5912 lines
101 KiB
XML

<test>
<!-- This is a large but valid query (Initially a valid query, obfuscated and tripled via UNION ALL) -->
<query short='1'>
<![CDATA[
EXPLAIN AST SELECT *
FROM
(
SELECT
c1,
c2,
c3_q[1] AS c3_q1,
c3_q[3] AS c3_q3,
c3_q[2] AS c3_median,
least(c3_max, c3_q3 + (1.5 * (c3_q3 - c3_q1))) AS c3_max,
greatest(c3_min, c3_q1 - (1.5 * (c3_q3 - c3_q1))) AS c3_min,
c3_avg,
c4_q[1] AS c4_q1,
c4_q[3] AS c4_q3,
c4_q[2] AS c4_median,
least(c4_max, c4_q3 + (1.5 * (c4_q3 - c4_q1))) AS c4_max,
greatest(c4_min, c4_q1 - (1.5 * (c4_q3 - c4_q1))) AS c4_min,
c4_avg,
c5_q[1] AS c5_q1,
c5_q[3] AS c5_q3,
c5_q[2] AS c5_median,
least(c5_max, c5_q3 + (1.5 * (c5_q3 - c5_q1))) AS c5_max,
greatest(c5_min, c5_q1 - (1.5 * (c5_q3 - c5_q1))) AS c5_min,
c5_avg,
c6_q[1] AS c6_q1,
c6_q[3] AS c6_q3,
c6_q[2] AS c6_median,
least(c6_max, c6_q3 + (1.5 * (c6_q3 - c6_q1))) AS c6_max,
greatest(c6_min, c6_q1 - (1.5 * (c6_q3 - c6_q1))) AS c6_min,
c6_avg,
c7_q[1] AS c7_q1,
c7_q[3] AS c7_q3,
c7_q[2] AS c7_median,
least(c7_max, c7_q3 + (1.5 * (c7_q3 - c7_q1))) AS c7_max,
greatest(c7_min, c7_q1 - (1.5 * (c7_q3 - c7_q1))) AS c7_min,
c7_avg,
c8_q[1] AS c8_q1,
c8_q[3] AS c8_q3,
c8_q[2] AS c8_median,
least(c8_max, c8_q3 + (1.5 * (c8_q3 - c8_q1))) AS c8_max,
greatest(c8_min, c8_q1 - (1.5 * (c8_q3 - c8_q1))) AS c8_min,
c8_avg,
c9_q[1] AS c9_q1,
c9_q[3] AS c9_q3,
c9_q[2] AS c9_median,
least(c9_max, c9_q3 + (1.5 * (c9_q3 - c9_q1))) AS c9_max,
greatest(c9_min, c9_q1 - (1.5 * (c9_q3 - c9_q1))) AS c9_min,
c9_avg,
c10_q[1] AS c10_q1,
c10_q[3] AS c10_q3,
c10_q[2] AS c10_median,
least(c10_max, c10_q3 + (1.5 * (c10_q3 - c10_q1))) AS c10_max,
greatest(c10_min, c10_q1 - (1.5 * (c10_q3 - c10_q1))) AS c10_min,
c10_avg,
c10_avg,
c11_q[1] AS c11_q1,
c11_q[3] AS c11_q3,
c11_q[2] AS c11_median,
least(c11_max, c11_q3 + (1.5 * (c11_q3 - c11_q1))) AS c11_max,
greatest(c11_min, c11_q1 - (1.5 * (c11_q3 - c11_q1))) AS c11_min,
c11_avg,
c12_q[1] AS c12_q1,
c12_q[3] AS c12_q3,
c12_q[2] AS c12_median,
least(c12_max, c12_q3 + (1.5 * (c12_q3 - c12_q1))) AS c12_max,
greatest(c12_min, c12_q1 - (1.5 * (c12_q3 - c12_q1))) AS c12_min,
c12_avg,
c13_q[1] AS c13_q1,
c13_q[3] AS c13_q3,
c13_q[2] AS c13_median,
least(c13_max, c13_q3 + (1.5 * (c13_q3 - c13_q1))) AS c13_max,
greatest(c13_min, c13_q1 - (1.5 * (c13_q3 - c13_q1))) AS c13_min,
c13_avg,
c14_q[1] AS c14_q1,
c14_q[3] AS c14_q3,
c14_q[2] AS c14_median,
least(c14_max, c14_q3 + (1.5 * (c14_q3 - c14_q1))) AS c14_max,
greatest(c14_min, c14_q1 - (1.5 * (c14_q3 - c14_q1))) AS c14_min,
c14_avg,
c15_q[1] AS c15_q1,
c15_q[3] AS c15_q3,
c15_q[2] AS c15_median,
least(c15_max, c15_q3 + (1.5 * (c15_q3 - c15_q1))) AS c15_max,
greatest(c15_min, c15_q1 - (1.5 * (c15_q3 - c15_q1))) AS c15_min,
c15_avg,
c16_q[1] AS c16_q1,
c16_q[3] AS c16_q3,
c16_q[2] AS c16_median,
least(toFloat64(c16_max), c16_q3 + (1.5 * (c16_q3 - c16_q1))) AS c16_max,
greatest(toFloat64(c16_min), c16_q1 - (1.5 * (c16_q3 - c16_q1))) AS c16_min,
c16_avg,
c17_q[1] AS c17_q1,
c17_q[3] AS c17_q3,
c17_q[2] AS c17_median,
least(toFloat64(c17_max), c17_q3 + (1.5 * (c17_q3 - c17_q1))) AS c17_max,
greatest(toFloat64(c17_min), c17_q1 - (1.5 * (c17_q3 - c17_q1))) AS c17_min,
c17_avg,
c18_q[1] AS c18_q1,
c18_q[3] AS c18_q3,
c18_q[2] AS c18_median,
least(toFloat64(c18_max), c18_q3 + (1.5 * (c18_q3 - c18_q1))) AS c18_max,
greatest(toFloat64(c18_min), c18_q1 - (1.5 * (c18_q3 - c18_q1))) AS c18_min,
c18_avg,
round(if(c19 != 0, c24 / c19, 0), 2) AS c20,
c21,
c22,
c23 AS c23,
c19 AS c19,
c16 AS c16,
c17 AS c17,
c18 AS c18,
round(c24, 2) AS c24,
round(if(c17 != 0, c24 / c17, 0), 2) AS c25,
'CH' AS c26
FROM
(
SELECT
c1,
c2,
groupUniqArray(c27) AS c28,
groupUniqArrayIf(c27, isNotNull(c29)) AS c28_with_c29,
quantiles(0.25, 0.5, 0.75)(if(c3 > 0, c3, NULL)) AS c3_q,
quantiles(0.25, 0.5, 0.75)(if(c4 > 0, c4, NULL)) AS c4_q,
quantiles(0.25, 0.5, 0.75)(t.c17 / t.c19) AS c5_q,
quantiles(0.25, 0.5, 0.75)(c6) AS c6_q,
quantiles(0.25, 0.5, 0.75)(c7) AS c7_q,
quantiles(0.25, 0.5, 0.75)(c8) AS c8_q,
quantiles(0.25, 0.5, 0.75)(c9) AS c9_q,
quantiles(0.25, 0.5, 0.75)(c10) AS c10_q,
quantiles(0.25, 0.5, 0.75)(c11) AS c11_q,
quantiles(0.25, 0.5, 0.75)(c12) AS c12_q,
quantiles(0.25, 0.5, 0.75)(c13) AS c13_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_q,
quantiles(0.25, 0.5, 0.75)(t.c16) AS c16_q,
quantiles(0.25, 0.5, 0.75)(t.c17) AS c17_q,
quantiles(0.25, 0.5, 0.75)(if(t.c18 > 0, t.c18, NULL)) AS c18_q,
max(if(c3 > 0, c3, NULL)) AS c3_max,
min(if(c3 > 0, c3, NULL)) AS c3_min,
avg(if(c3 > 0, c3, NULL)) AS c3_avg,
max(if(c4 > 0, c4, NULL)) AS c4_max,
min(if(c4 > 0, c4, NULL)) AS c4_min,
avg(if(c4 > 0, c4, NULL)) AS c4_avg,
max(t.c17 / t.c19) AS c5_max,
min(t.c17 / t.c19) AS c5_min,
avg(t.c17 / t.c19) AS c5_avg,
max(if(c6 > 0, c6, NULL)) AS c6_max,
min(if(c6 > 0, c6, NULL)) AS c6_min,
avg(if(c6 > 0, c6, NULL)) AS c6_avg,
max(if(c7 > 0, c7, NULL)) AS c7_max,
min(if(c7 > 0, c7, NULL)) AS c7_min,
avg(if(c7 > 0, c7, NULL)) AS c7_avg,
max(if(c10 > 0, c10, NULL)) AS c10_max,
min(if(c10 > 0, c10, NULL)) AS c10_min,
avg(if(c10 > 0, c10, NULL)) AS c10_avg,
max(if(c8 > 0, c8, NULL)) AS c8_max,
min(if(c8 > 0, c8, NULL)) AS c8_min,
avg(if(c8 > 0, c8, NULL)) AS c8_avg,
max(if(c9 > 0, c9, NULL)) AS c9_max,
min(if(c9 > 0, c9, NULL)) AS c9_min,
avg(if(c9 > 0, c9, NULL)) AS c9_avg,
max(if(c11 > 0, c11, NULL)) AS c11_max,
min(if(c11 > 0, c11, NULL)) AS c11_min,
avg(if(c11 > 0, c11, NULL)) AS c11_avg,
max(if(c12 > 0, c12, NULL)) AS c12_max,
min(if(c12 > 0, c12, NULL)) AS c12_min,
avg(if(c12 > 0, c12, NULL)) AS c12_avg,
max(if(c13 > 0, c13, NULL)) AS c13_max,
min(if(c13 > 0, c13, NULL)) AS c13_min,
avg(if(c13 > 0, c13, NULL)) AS c13_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_avg,
max(t.c16) AS c16_max,
min(t.c16) AS c16_min,
avg(t.c16) AS c16_avg,
max(t.c17) AS c17_max,
min(t.c17) AS c17_min,
avg(t.c17) AS c17_avg,
max(if(t.c18 > 0, t.c18, NULL)) AS c18_max,
min(if(t.c18 > 0, t.c18, NULL)) AS c18_min,
avg(if(t.c18 > 0, t.c18, NULL)) AS c18_avg,
sum(t.c19) AS c19,
sum(if(t.c18 > 0, t.c18, NULL)) AS c18,
sum(t.c16) AS c16,
sum(c23) AS c23,
sum(t.c17) AS c17,
sum(if(t.c24 > 0, t.c24, NULL)) AS c24,
c24 / c19 AS c14,
c24 / c17 AS c15,
median(if(isNotNull(c29) AND (t.c22 > 0), c13 * (t.c22 / c29), NULL)) AS c21,
sum(c22) AS c22
FROM
(
SELECT
c27,
c39 AS c1,
c29,
c19,
c23,
c17,
c16,
c18,
c22,
c24,
c3,
c4,
c8,
c9,
c10,
c11,
c12,
c13,
c6,
c7
FROM
(
SELECT
c27,
uniqExact(c30, c31) AS c19,
uniqExact(c30, c31, c32) AS c23,
uniqExactIf(c30, c31, c33 IN ('c37', 'c38')) AS c17,
countIf(c33 IN ('c37', 'c38')) AS c16,
countIf(c33 = 'c39') AS c18,
coalesce(sumIf(c29, c33 = 'c39'), 0) AS c22,
coalesce(sumIf(c37, c33 = 'c39'), 0) AS c24,
if((c18 > 0) AND (c19 > 0), c18 / c19, NULL) AS c3,
if(c17 != 0, c18 / c17, NULL) AS c4,
coalesce(avgIf(c34, (c34 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c8,
coalesce(avgIf(c35, (c35 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c9,
coalesce(avgIf(c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c10,
coalesce(avgIf(c35, (c35 > 0) AND (c33 = 'c39')), NULL) AS c11,
coalesce(avgIf(c37, c33 = 'c39'), NULL) AS c12,
coalesce(avgIf(c37 / c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c13,
coalesce(avgIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c6,
coalesce(minIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38')) AND (c37 > (c36 / 2))), NULL) AS c7
FROM
(
SELECT
c27,
c30,
c32,
c31,
NULL AS c29,
NULL AS c33,
NULL AS c37,
NULL AS c34,
NULL AS c35
FROM
(
SELECT
c27,
c30,
c32,
c31
FROM database.t1
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE c61 = 0
) AS table25
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c37' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table24
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table23
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c39' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table22
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table21
) AS table20
ALL LEFT JOIN
(
SELECT
c27,
avgMerge(avg_c37) * joinGet('database.table18', 'c60', concat('USD', '_', 'CH')) AS c36
FROM database.table19
PREWHERE c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
)
WHERE date > (now() - toIntervalMonth(3))
GROUP BY c27
) AS table17 USING (c27)
GROUP BY c27
) AS table16
ALL LEFT JOIN
(
SELECT
comp_c27 AS c27,
assumeNotNull(c39) AS c39,
c29
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
) USING (c27)
) AS t
ALL LEFT JOIN
(
SELECT
c1,
c2
FROM
(
SELECT
c39 AS c1,
groupArray(comp_c27) AS c49,
multiIf(c1 = 'c58', if(length(c49) <= 2, 0, 1), c1 = 'c57', 1, if(length(c49) <= 3, 0, 1)) AS c2
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
GROUP BY c39
) AS table3
) USING (c1)
GROUP BY
c1,
c2
) AS table2
ORDER BY c1 ASC
) AS table1
UNION ALL
SELECT *
FROM
(
SELECT
c1,
c2,
c3_q[1] AS c3_q1,
c3_q[3] AS c3_q3,
c3_q[2] AS c3_median,
least(c3_max, c3_q3 + (1.5 * (c3_q3 - c3_q1))) AS c3_max,
greatest(c3_min, c3_q1 - (1.5 * (c3_q3 - c3_q1))) AS c3_min,
c3_avg,
c4_q[1] AS c4_q1,
c4_q[3] AS c4_q3,
c4_q[2] AS c4_median,
least(c4_max, c4_q3 + (1.5 * (c4_q3 - c4_q1))) AS c4_max,
greatest(c4_min, c4_q1 - (1.5 * (c4_q3 - c4_q1))) AS c4_min,
c4_avg,
c5_q[1] AS c5_q1,
c5_q[3] AS c5_q3,
c5_q[2] AS c5_median,
least(c5_max, c5_q3 + (1.5 * (c5_q3 - c5_q1))) AS c5_max,
greatest(c5_min, c5_q1 - (1.5 * (c5_q3 - c5_q1))) AS c5_min,
c5_avg,
c6_q[1] AS c6_q1,
c6_q[3] AS c6_q3,
c6_q[2] AS c6_median,
least(c6_max, c6_q3 + (1.5 * (c6_q3 - c6_q1))) AS c6_max,
greatest(c6_min, c6_q1 - (1.5 * (c6_q3 - c6_q1))) AS c6_min,
c6_avg,
c7_q[1] AS c7_q1,
c7_q[3] AS c7_q3,
c7_q[2] AS c7_median,
least(c7_max, c7_q3 + (1.5 * (c7_q3 - c7_q1))) AS c7_max,
greatest(c7_min, c7_q1 - (1.5 * (c7_q3 - c7_q1))) AS c7_min,
c7_avg,
c8_q[1] AS c8_q1,
c8_q[3] AS c8_q3,
c8_q[2] AS c8_median,
least(c8_max, c8_q3 + (1.5 * (c8_q3 - c8_q1))) AS c8_max,
greatest(c8_min, c8_q1 - (1.5 * (c8_q3 - c8_q1))) AS c8_min,
c8_avg,
c9_q[1] AS c9_q1,
c9_q[3] AS c9_q3,
c9_q[2] AS c9_median,
least(c9_max, c9_q3 + (1.5 * (c9_q3 - c9_q1))) AS c9_max,
greatest(c9_min, c9_q1 - (1.5 * (c9_q3 - c9_q1))) AS c9_min,
c9_avg,
c10_q[1] AS c10_q1,
c10_q[3] AS c10_q3,
c10_q[2] AS c10_median,
least(c10_max, c10_q3 + (1.5 * (c10_q3 - c10_q1))) AS c10_max,
greatest(c10_min, c10_q1 - (1.5 * (c10_q3 - c10_q1))) AS c10_min,
c10_avg,
c10_avg,
c11_q[1] AS c11_q1,
c11_q[3] AS c11_q3,
c11_q[2] AS c11_median,
least(c11_max, c11_q3 + (1.5 * (c11_q3 - c11_q1))) AS c11_max,
greatest(c11_min, c11_q1 - (1.5 * (c11_q3 - c11_q1))) AS c11_min,
c11_avg,
c12_q[1] AS c12_q1,
c12_q[3] AS c12_q3,
c12_q[2] AS c12_median,
least(c12_max, c12_q3 + (1.5 * (c12_q3 - c12_q1))) AS c12_max,
greatest(c12_min, c12_q1 - (1.5 * (c12_q3 - c12_q1))) AS c12_min,
c12_avg,
c13_q[1] AS c13_q1,
c13_q[3] AS c13_q3,
c13_q[2] AS c13_median,
least(c13_max, c13_q3 + (1.5 * (c13_q3 - c13_q1))) AS c13_max,
greatest(c13_min, c13_q1 - (1.5 * (c13_q3 - c13_q1))) AS c13_min,
c13_avg,
c14_q[1] AS c14_q1,
c14_q[3] AS c14_q3,
c14_q[2] AS c14_median,
least(c14_max, c14_q3 + (1.5 * (c14_q3 - c14_q1))) AS c14_max,
greatest(c14_min, c14_q1 - (1.5 * (c14_q3 - c14_q1))) AS c14_min,
c14_avg,
c15_q[1] AS c15_q1,
c15_q[3] AS c15_q3,
c15_q[2] AS c15_median,
least(c15_max, c15_q3 + (1.5 * (c15_q3 - c15_q1))) AS c15_max,
greatest(c15_min, c15_q1 - (1.5 * (c15_q3 - c15_q1))) AS c15_min,
c15_avg,
c16_q[1] AS c16_q1,
c16_q[3] AS c16_q3,
c16_q[2] AS c16_median,
least(toFloat64(c16_max), c16_q3 + (1.5 * (c16_q3 - c16_q1))) AS c16_max,
greatest(toFloat64(c16_min), c16_q1 - (1.5 * (c16_q3 - c16_q1))) AS c16_min,
c16_avg,
c17_q[1] AS c17_q1,
c17_q[3] AS c17_q3,
c17_q[2] AS c17_median,
least(toFloat64(c17_max), c17_q3 + (1.5 * (c17_q3 - c17_q1))) AS c17_max,
greatest(toFloat64(c17_min), c17_q1 - (1.5 * (c17_q3 - c17_q1))) AS c17_min,
c17_avg,
c18_q[1] AS c18_q1,
c18_q[3] AS c18_q3,
c18_q[2] AS c18_median,
least(toFloat64(c18_max), c18_q3 + (1.5 * (c18_q3 - c18_q1))) AS c18_max,
greatest(toFloat64(c18_min), c18_q1 - (1.5 * (c18_q3 - c18_q1))) AS c18_min,
c18_avg,
round(if(c19 != 0, c24 / c19, 0), 2) AS c20,
c21,
c22,
c23 AS c23,
c19 AS c19,
c16 AS c16,
c17 AS c17,
c18 AS c18,
round(c24, 2) AS c24,
round(if(c17 != 0, c24 / c17, 0), 2) AS c25,
'CH' AS c26
FROM
(
SELECT
c1,
c2,
groupUniqArray(c27) AS c28,
groupUniqArrayIf(c27, isNotNull(c29)) AS c28_with_c29,
quantiles(0.25, 0.5, 0.75)(if(c3 > 0, c3, NULL)) AS c3_q,
quantiles(0.25, 0.5, 0.75)(if(c4 > 0, c4, NULL)) AS c4_q,
quantiles(0.25, 0.5, 0.75)(t.c17 / t.c19) AS c5_q,
quantiles(0.25, 0.5, 0.75)(c6) AS c6_q,
quantiles(0.25, 0.5, 0.75)(c7) AS c7_q,
quantiles(0.25, 0.5, 0.75)(c8) AS c8_q,
quantiles(0.25, 0.5, 0.75)(c9) AS c9_q,
quantiles(0.25, 0.5, 0.75)(c10) AS c10_q,
quantiles(0.25, 0.5, 0.75)(c11) AS c11_q,
quantiles(0.25, 0.5, 0.75)(c12) AS c12_q,
quantiles(0.25, 0.5, 0.75)(c13) AS c13_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_q,
quantiles(0.25, 0.5, 0.75)(t.c16) AS c16_q,
quantiles(0.25, 0.5, 0.75)(t.c17) AS c17_q,
quantiles(0.25, 0.5, 0.75)(if(t.c18 > 0, t.c18, NULL)) AS c18_q,
max(if(c3 > 0, c3, NULL)) AS c3_max,
min(if(c3 > 0, c3, NULL)) AS c3_min,
avg(if(c3 > 0, c3, NULL)) AS c3_avg,
max(if(c4 > 0, c4, NULL)) AS c4_max,
min(if(c4 > 0, c4, NULL)) AS c4_min,
avg(if(c4 > 0, c4, NULL)) AS c4_avg,
max(t.c17 / t.c19) AS c5_max,
min(t.c17 / t.c19) AS c5_min,
avg(t.c17 / t.c19) AS c5_avg,
max(if(c6 > 0, c6, NULL)) AS c6_max,
min(if(c6 > 0, c6, NULL)) AS c6_min,
avg(if(c6 > 0, c6, NULL)) AS c6_avg,
max(if(c7 > 0, c7, NULL)) AS c7_max,
min(if(c7 > 0, c7, NULL)) AS c7_min,
avg(if(c7 > 0, c7, NULL)) AS c7_avg,
max(if(c10 > 0, c10, NULL)) AS c10_max,
min(if(c10 > 0, c10, NULL)) AS c10_min,
avg(if(c10 > 0, c10, NULL)) AS c10_avg,
max(if(c8 > 0, c8, NULL)) AS c8_max,
min(if(c8 > 0, c8, NULL)) AS c8_min,
avg(if(c8 > 0, c8, NULL)) AS c8_avg,
max(if(c9 > 0, c9, NULL)) AS c9_max,
min(if(c9 > 0, c9, NULL)) AS c9_min,
avg(if(c9 > 0, c9, NULL)) AS c9_avg,
max(if(c11 > 0, c11, NULL)) AS c11_max,
min(if(c11 > 0, c11, NULL)) AS c11_min,
avg(if(c11 > 0, c11, NULL)) AS c11_avg,
max(if(c12 > 0, c12, NULL)) AS c12_max,
min(if(c12 > 0, c12, NULL)) AS c12_min,
avg(if(c12 > 0, c12, NULL)) AS c12_avg,
max(if(c13 > 0, c13, NULL)) AS c13_max,
min(if(c13 > 0, c13, NULL)) AS c13_min,
avg(if(c13 > 0, c13, NULL)) AS c13_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_avg,
max(t.c16) AS c16_max,
min(t.c16) AS c16_min,
avg(t.c16) AS c16_avg,
max(t.c17) AS c17_max,
min(t.c17) AS c17_min,
avg(t.c17) AS c17_avg,
max(if(t.c18 > 0, t.c18, NULL)) AS c18_max,
min(if(t.c18 > 0, t.c18, NULL)) AS c18_min,
avg(if(t.c18 > 0, t.c18, NULL)) AS c18_avg,
sum(t.c19) AS c19,
sum(if(t.c18 > 0, t.c18, NULL)) AS c18,
sum(t.c16) AS c16,
sum(c23) AS c23,
sum(t.c17) AS c17,
sum(if(t.c24 > 0, t.c24, NULL)) AS c24,
c24 / c19 AS c14,
c24 / c17 AS c15,
median(if(isNotNull(c29) AND (t.c22 > 0), c13 * (t.c22 / c29), NULL)) AS c21,
sum(c22) AS c22
FROM
(
SELECT
c27,
c39 AS c1,
c29,
c19,
c23,
c17,
c16,
c18,
c22,
c24,
c3,
c4,
c8,
c9,
c10,
c11,
c12,
c13,
c6,
c7
FROM
(
SELECT
c27,
uniqExact(c30, c31) AS c19,
uniqExact(c30, c31, c32) AS c23,
uniqExactIf(c30, c31, c33 IN ('c37', 'c38')) AS c17,
countIf(c33 IN ('c37', 'c38')) AS c16,
countIf(c33 = 'c39') AS c18,
coalesce(sumIf(c29, c33 = 'c39'), 0) AS c22,
coalesce(sumIf(c37, c33 = 'c39'), 0) AS c24,
if((c18 > 0) AND (c19 > 0), c18 / c19, NULL) AS c3,
if(c17 != 0, c18 / c17, NULL) AS c4,
coalesce(avgIf(c34, (c34 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c8,
coalesce(avgIf(c35, (c35 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c9,
coalesce(avgIf(c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c10,
coalesce(avgIf(c35, (c35 > 0) AND (c33 = 'c39')), NULL) AS c11,
coalesce(avgIf(c37, c33 = 'c39'), NULL) AS c12,
coalesce(avgIf(c37 / c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c13,
coalesce(avgIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c6,
coalesce(minIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38')) AND (c37 > (c36 / 2))), NULL) AS c7
FROM
(
SELECT
c27,
c30,
c32,
c31,
NULL AS c29,
NULL AS c33,
NULL AS c37,
NULL AS c34,
NULL AS c35
FROM
(
SELECT
c27,
c30,
c32,
c31
FROM database.t1
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE c61 = 0
) AS table25
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c37' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table24
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table23
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c39' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table22
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table21
) AS table20
ALL LEFT JOIN
(
SELECT
c27,
avgMerge(avg_c37) * joinGet('database.table18', 'c60', concat('USD', '_', 'CH')) AS c36
FROM database.table19
PREWHERE c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
)
WHERE date > (now() - toIntervalMonth(3))
GROUP BY c27
) AS table17 USING (c27)
GROUP BY c27
) AS table16
ALL LEFT JOIN
(
SELECT
comp_c27 AS c27,
assumeNotNull(c39) AS c39,
c29
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
) USING (c27)
) AS t
ALL LEFT JOIN
(
SELECT
c1,
c2
FROM
(
SELECT
c39 AS c1,
groupArray(comp_c27) AS c49,
multiIf(c1 = 'c58', if(length(c49) <= 2, 0, 1), c1 = 'c57', 1, if(length(c49) <= 3, 0, 1)) AS c2
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
GROUP BY c39
) AS table3
) USING (c1)
GROUP BY
c1,
c2
) AS table2
ORDER BY c1 ASC
) AS table1
UNION ALL
SELECT *
FROM
(
SELECT
c1,
c2,
c3_q[1] AS c3_q1,
c3_q[3] AS c3_q3,
c3_q[2] AS c3_median,
least(c3_max, c3_q3 + (1.5 * (c3_q3 - c3_q1))) AS c3_max,
greatest(c3_min, c3_q1 - (1.5 * (c3_q3 - c3_q1))) AS c3_min,
c3_avg,
c4_q[1] AS c4_q1,
c4_q[3] AS c4_q3,
c4_q[2] AS c4_median,
least(c4_max, c4_q3 + (1.5 * (c4_q3 - c4_q1))) AS c4_max,
greatest(c4_min, c4_q1 - (1.5 * (c4_q3 - c4_q1))) AS c4_min,
c4_avg,
c5_q[1] AS c5_q1,
c5_q[3] AS c5_q3,
c5_q[2] AS c5_median,
least(c5_max, c5_q3 + (1.5 * (c5_q3 - c5_q1))) AS c5_max,
greatest(c5_min, c5_q1 - (1.5 * (c5_q3 - c5_q1))) AS c5_min,
c5_avg,
c6_q[1] AS c6_q1,
c6_q[3] AS c6_q3,
c6_q[2] AS c6_median,
least(c6_max, c6_q3 + (1.5 * (c6_q3 - c6_q1))) AS c6_max,
greatest(c6_min, c6_q1 - (1.5 * (c6_q3 - c6_q1))) AS c6_min,
c6_avg,
c7_q[1] AS c7_q1,
c7_q[3] AS c7_q3,
c7_q[2] AS c7_median,
least(c7_max, c7_q3 + (1.5 * (c7_q3 - c7_q1))) AS c7_max,
greatest(c7_min, c7_q1 - (1.5 * (c7_q3 - c7_q1))) AS c7_min,
c7_avg,
c8_q[1] AS c8_q1,
c8_q[3] AS c8_q3,
c8_q[2] AS c8_median,
least(c8_max, c8_q3 + (1.5 * (c8_q3 - c8_q1))) AS c8_max,
greatest(c8_min, c8_q1 - (1.5 * (c8_q3 - c8_q1))) AS c8_min,
c8_avg,
c9_q[1] AS c9_q1,
c9_q[3] AS c9_q3,
c9_q[2] AS c9_median,
least(c9_max, c9_q3 + (1.5 * (c9_q3 - c9_q1))) AS c9_max,
greatest(c9_min, c9_q1 - (1.5 * (c9_q3 - c9_q1))) AS c9_min,
c9_avg,
c10_q[1] AS c10_q1,
c10_q[3] AS c10_q3,
c10_q[2] AS c10_median,
least(c10_max, c10_q3 + (1.5 * (c10_q3 - c10_q1))) AS c10_max,
greatest(c10_min, c10_q1 - (1.5 * (c10_q3 - c10_q1))) AS c10_min,
c10_avg,
c10_avg,
c11_q[1] AS c11_q1,
c11_q[3] AS c11_q3,
c11_q[2] AS c11_median,
least(c11_max, c11_q3 + (1.5 * (c11_q3 - c11_q1))) AS c11_max,
greatest(c11_min, c11_q1 - (1.5 * (c11_q3 - c11_q1))) AS c11_min,
c11_avg,
c12_q[1] AS c12_q1,
c12_q[3] AS c12_q3,
c12_q[2] AS c12_median,
least(c12_max, c12_q3 + (1.5 * (c12_q3 - c12_q1))) AS c12_max,
greatest(c12_min, c12_q1 - (1.5 * (c12_q3 - c12_q1))) AS c12_min,
c12_avg,
c13_q[1] AS c13_q1,
c13_q[3] AS c13_q3,
c13_q[2] AS c13_median,
least(c13_max, c13_q3 + (1.5 * (c13_q3 - c13_q1))) AS c13_max,
greatest(c13_min, c13_q1 - (1.5 * (c13_q3 - c13_q1))) AS c13_min,
c13_avg,
c14_q[1] AS c14_q1,
c14_q[3] AS c14_q3,
c14_q[2] AS c14_median,
least(c14_max, c14_q3 + (1.5 * (c14_q3 - c14_q1))) AS c14_max,
greatest(c14_min, c14_q1 - (1.5 * (c14_q3 - c14_q1))) AS c14_min,
c14_avg,
c15_q[1] AS c15_q1,
c15_q[3] AS c15_q3,
c15_q[2] AS c15_median,
least(c15_max, c15_q3 + (1.5 * (c15_q3 - c15_q1))) AS c15_max,
greatest(c15_min, c15_q1 - (1.5 * (c15_q3 - c15_q1))) AS c15_min,
c15_avg,
c16_q[1] AS c16_q1,
c16_q[3] AS c16_q3,
c16_q[2] AS c16_median,
least(toFloat64(c16_max), c16_q3 + (1.5 * (c16_q3 - c16_q1))) AS c16_max,
greatest(toFloat64(c16_min), c16_q1 - (1.5 * (c16_q3 - c16_q1))) AS c16_min,
c16_avg,
c17_q[1] AS c17_q1,
c17_q[3] AS c17_q3,
c17_q[2] AS c17_median,
least(toFloat64(c17_max), c17_q3 + (1.5 * (c17_q3 - c17_q1))) AS c17_max,
greatest(toFloat64(c17_min), c17_q1 - (1.5 * (c17_q3 - c17_q1))) AS c17_min,
c17_avg,
c18_q[1] AS c18_q1,
c18_q[3] AS c18_q3,
c18_q[2] AS c18_median,
least(toFloat64(c18_max), c18_q3 + (1.5 * (c18_q3 - c18_q1))) AS c18_max,
greatest(toFloat64(c18_min), c18_q1 - (1.5 * (c18_q3 - c18_q1))) AS c18_min,
c18_avg,
round(if(c19 != 0, c24 / c19, 0), 2) AS c20,
c21,
c22,
c23 AS c23,
c19 AS c19,
c16 AS c16,
c17 AS c17,
c18 AS c18,
round(c24, 2) AS c24,
round(if(c17 != 0, c24 / c17, 0), 2) AS c25,
'CH' AS c26
FROM
(
SELECT
c1,
c2,
groupUniqArray(c27) AS c28,
groupUniqArrayIf(c27, isNotNull(c29)) AS c28_with_c29,
quantiles(0.25, 0.5, 0.75)(if(c3 > 0, c3, NULL)) AS c3_q,
quantiles(0.25, 0.5, 0.75)(if(c4 > 0, c4, NULL)) AS c4_q,
quantiles(0.25, 0.5, 0.75)(t.c17 / t.c19) AS c5_q,
quantiles(0.25, 0.5, 0.75)(c6) AS c6_q,
quantiles(0.25, 0.5, 0.75)(c7) AS c7_q,
quantiles(0.25, 0.5, 0.75)(c8) AS c8_q,
quantiles(0.25, 0.5, 0.75)(c9) AS c9_q,
quantiles(0.25, 0.5, 0.75)(c10) AS c10_q,
quantiles(0.25, 0.5, 0.75)(c11) AS c11_q,
quantiles(0.25, 0.5, 0.75)(c12) AS c12_q,
quantiles(0.25, 0.5, 0.75)(c13) AS c13_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_q,
quantiles(0.25, 0.5, 0.75)(t.c16) AS c16_q,
quantiles(0.25, 0.5, 0.75)(t.c17) AS c17_q,
quantiles(0.25, 0.5, 0.75)(if(t.c18 > 0, t.c18, NULL)) AS c18_q,
max(if(c3 > 0, c3, NULL)) AS c3_max,
min(if(c3 > 0, c3, NULL)) AS c3_min,
avg(if(c3 > 0, c3, NULL)) AS c3_avg,
max(if(c4 > 0, c4, NULL)) AS c4_max,
min(if(c4 > 0, c4, NULL)) AS c4_min,
avg(if(c4 > 0, c4, NULL)) AS c4_avg,
max(t.c17 / t.c19) AS c5_max,
min(t.c17 / t.c19) AS c5_min,
avg(t.c17 / t.c19) AS c5_avg,
max(if(c6 > 0, c6, NULL)) AS c6_max,
min(if(c6 > 0, c6, NULL)) AS c6_min,
avg(if(c6 > 0, c6, NULL)) AS c6_avg,
max(if(c7 > 0, c7, NULL)) AS c7_max,
min(if(c7 > 0, c7, NULL)) AS c7_min,
avg(if(c7 > 0, c7, NULL)) AS c7_avg,
max(if(c10 > 0, c10, NULL)) AS c10_max,
min(if(c10 > 0, c10, NULL)) AS c10_min,
avg(if(c10 > 0, c10, NULL)) AS c10_avg,
max(if(c8 > 0, c8, NULL)) AS c8_max,
min(if(c8 > 0, c8, NULL)) AS c8_min,
avg(if(c8 > 0, c8, NULL)) AS c8_avg,
max(if(c9 > 0, c9, NULL)) AS c9_max,
min(if(c9 > 0, c9, NULL)) AS c9_min,
avg(if(c9 > 0, c9, NULL)) AS c9_avg,
max(if(c11 > 0, c11, NULL)) AS c11_max,
min(if(c11 > 0, c11, NULL)) AS c11_min,
avg(if(c11 > 0, c11, NULL)) AS c11_avg,
max(if(c12 > 0, c12, NULL)) AS c12_max,
min(if(c12 > 0, c12, NULL)) AS c12_min,
avg(if(c12 > 0, c12, NULL)) AS c12_avg,
max(if(c13 > 0, c13, NULL)) AS c13_max,
min(if(c13 > 0, c13, NULL)) AS c13_min,
avg(if(c13 > 0, c13, NULL)) AS c13_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_avg,
max(t.c16) AS c16_max,
min(t.c16) AS c16_min,
avg(t.c16) AS c16_avg,
max(t.c17) AS c17_max,
min(t.c17) AS c17_min,
avg(t.c17) AS c17_avg,
max(if(t.c18 > 0, t.c18, NULL)) AS c18_max,
min(if(t.c18 > 0, t.c18, NULL)) AS c18_min,
avg(if(t.c18 > 0, t.c18, NULL)) AS c18_avg,
sum(t.c19) AS c19,
sum(if(t.c18 > 0, t.c18, NULL)) AS c18,
sum(t.c16) AS c16,
sum(c23) AS c23,
sum(t.c17) AS c17,
sum(if(t.c24 > 0, t.c24, NULL)) AS c24,
c24 / c19 AS c14,
c24 / c17 AS c15,
median(if(isNotNull(c29) AND (t.c22 > 0), c13 * (t.c22 / c29), NULL)) AS c21,
sum(c22) AS c22
FROM
(
SELECT
c27,
c39 AS c1,
c29,
c19,
c23,
c17,
c16,
c18,
c22,
c24,
c3,
c4,
c8,
c9,
c10,
c11,
c12,
c13,
c6,
c7
FROM
(
SELECT
c27,
uniqExact(c30, c31) AS c19,
uniqExact(c30, c31, c32) AS c23,
uniqExactIf(c30, c31, c33 IN ('c37', 'c38')) AS c17,
countIf(c33 IN ('c37', 'c38')) AS c16,
countIf(c33 = 'c39') AS c18,
coalesce(sumIf(c29, c33 = 'c39'), 0) AS c22,
coalesce(sumIf(c37, c33 = 'c39'), 0) AS c24,
if((c18 > 0) AND (c19 > 0), c18 / c19, NULL) AS c3,
if(c17 != 0, c18 / c17, NULL) AS c4,
coalesce(avgIf(c34, (c34 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c8,
coalesce(avgIf(c35, (c35 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c9,
coalesce(avgIf(c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c10,
coalesce(avgIf(c35, (c35 > 0) AND (c33 = 'c39')), NULL) AS c11,
coalesce(avgIf(c37, c33 = 'c39'), NULL) AS c12,
coalesce(avgIf(c37 / c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c13,
coalesce(avgIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c6,
coalesce(minIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38')) AND (c37 > (c36 / 2))), NULL) AS c7
FROM
(
SELECT
c27,
c30,
c32,
c31,
NULL AS c29,
NULL AS c33,
NULL AS c37,
NULL AS c34,
NULL AS c35
FROM
(
SELECT
c27,
c30,
c32,
c31
FROM database.t1
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE c61 = 0
) AS table25
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c37' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table24
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table23
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c39' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table22
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table21
) AS table20
ALL LEFT JOIN
(
SELECT
c27,
avgMerge(avg_c37) * joinGet('database.table18', 'c60', concat('USD', '_', 'CH')) AS c36
FROM database.table19
PREWHERE c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
)
WHERE date > (now() - toIntervalMonth(3))
GROUP BY c27
) AS table17 USING (c27)
GROUP BY c27
) AS table16
ALL LEFT JOIN
(
SELECT
comp_c27 AS c27,
assumeNotNull(c39) AS c39,
c29
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
) USING (c27)
) AS t
ALL LEFT JOIN
(
SELECT
c1,
c2
FROM
(
SELECT
c39 AS c1,
groupArray(comp_c27) AS c49,
multiIf(c1 = 'c58', if(length(c49) <= 2, 0, 1), c1 = 'c57', 1, if(length(c49) <= 3, 0, 1)) AS c2
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
GROUP BY c39
) AS table3
) USING (c1)
GROUP BY
c1,
c2
) AS table2
ORDER BY c1 ASC
) AS table1
UNION ALL
SELECT *
FROM
(
SELECT
c1,
c2,
c3_q[1] AS c3_q1,
c3_q[3] AS c3_q3,
c3_q[2] AS c3_median,
least(c3_max, c3_q3 + (1.5 * (c3_q3 - c3_q1))) AS c3_max,
greatest(c3_min, c3_q1 - (1.5 * (c3_q3 - c3_q1))) AS c3_min,
c3_avg,
c4_q[1] AS c4_q1,
c4_q[3] AS c4_q3,
c4_q[2] AS c4_median,
least(c4_max, c4_q3 + (1.5 * (c4_q3 - c4_q1))) AS c4_max,
greatest(c4_min, c4_q1 - (1.5 * (c4_q3 - c4_q1))) AS c4_min,
c4_avg,
c5_q[1] AS c5_q1,
c5_q[3] AS c5_q3,
c5_q[2] AS c5_median,
least(c5_max, c5_q3 + (1.5 * (c5_q3 - c5_q1))) AS c5_max,
greatest(c5_min, c5_q1 - (1.5 * (c5_q3 - c5_q1))) AS c5_min,
c5_avg,
c6_q[1] AS c6_q1,
c6_q[3] AS c6_q3,
c6_q[2] AS c6_median,
least(c6_max, c6_q3 + (1.5 * (c6_q3 - c6_q1))) AS c6_max,
greatest(c6_min, c6_q1 - (1.5 * (c6_q3 - c6_q1))) AS c6_min,
c6_avg,
c7_q[1] AS c7_q1,
c7_q[3] AS c7_q3,
c7_q[2] AS c7_median,
least(c7_max, c7_q3 + (1.5 * (c7_q3 - c7_q1))) AS c7_max,
greatest(c7_min, c7_q1 - (1.5 * (c7_q3 - c7_q1))) AS c7_min,
c7_avg,
c8_q[1] AS c8_q1,
c8_q[3] AS c8_q3,
c8_q[2] AS c8_median,
least(c8_max, c8_q3 + (1.5 * (c8_q3 - c8_q1))) AS c8_max,
greatest(c8_min, c8_q1 - (1.5 * (c8_q3 - c8_q1))) AS c8_min,
c8_avg,
c9_q[1] AS c9_q1,
c9_q[3] AS c9_q3,
c9_q[2] AS c9_median,
least(c9_max, c9_q3 + (1.5 * (c9_q3 - c9_q1))) AS c9_max,
greatest(c9_min, c9_q1 - (1.5 * (c9_q3 - c9_q1))) AS c9_min,
c9_avg,
c10_q[1] AS c10_q1,
c10_q[3] AS c10_q3,
c10_q[2] AS c10_median,
least(c10_max, c10_q3 + (1.5 * (c10_q3 - c10_q1))) AS c10_max,
greatest(c10_min, c10_q1 - (1.5 * (c10_q3 - c10_q1))) AS c10_min,
c10_avg,
c10_avg,
c11_q[1] AS c11_q1,
c11_q[3] AS c11_q3,
c11_q[2] AS c11_median,
least(c11_max, c11_q3 + (1.5 * (c11_q3 - c11_q1))) AS c11_max,
greatest(c11_min, c11_q1 - (1.5 * (c11_q3 - c11_q1))) AS c11_min,
c11_avg,
c12_q[1] AS c12_q1,
c12_q[3] AS c12_q3,
c12_q[2] AS c12_median,
least(c12_max, c12_q3 + (1.5 * (c12_q3 - c12_q1))) AS c12_max,
greatest(c12_min, c12_q1 - (1.5 * (c12_q3 - c12_q1))) AS c12_min,
c12_avg,
c13_q[1] AS c13_q1,
c13_q[3] AS c13_q3,
c13_q[2] AS c13_median,
least(c13_max, c13_q3 + (1.5 * (c13_q3 - c13_q1))) AS c13_max,
greatest(c13_min, c13_q1 - (1.5 * (c13_q3 - c13_q1))) AS c13_min,
c13_avg,
c14_q[1] AS c14_q1,
c14_q[3] AS c14_q3,
c14_q[2] AS c14_median,
least(c14_max, c14_q3 + (1.5 * (c14_q3 - c14_q1))) AS c14_max,
greatest(c14_min, c14_q1 - (1.5 * (c14_q3 - c14_q1))) AS c14_min,
c14_avg,
c15_q[1] AS c15_q1,
c15_q[3] AS c15_q3,
c15_q[2] AS c15_median,
least(c15_max, c15_q3 + (1.5 * (c15_q3 - c15_q1))) AS c15_max,
greatest(c15_min, c15_q1 - (1.5 * (c15_q3 - c15_q1))) AS c15_min,
c15_avg,
c16_q[1] AS c16_q1,
c16_q[3] AS c16_q3,
c16_q[2] AS c16_median,
least(toFloat64(c16_max), c16_q3 + (1.5 * (c16_q3 - c16_q1))) AS c16_max,
greatest(toFloat64(c16_min), c16_q1 - (1.5 * (c16_q3 - c16_q1))) AS c16_min,
c16_avg,
c17_q[1] AS c17_q1,
c17_q[3] AS c17_q3,
c17_q[2] AS c17_median,
least(toFloat64(c17_max), c17_q3 + (1.5 * (c17_q3 - c17_q1))) AS c17_max,
greatest(toFloat64(c17_min), c17_q1 - (1.5 * (c17_q3 - c17_q1))) AS c17_min,
c17_avg,
c18_q[1] AS c18_q1,
c18_q[3] AS c18_q3,
c18_q[2] AS c18_median,
least(toFloat64(c18_max), c18_q3 + (1.5 * (c18_q3 - c18_q1))) AS c18_max,
greatest(toFloat64(c18_min), c18_q1 - (1.5 * (c18_q3 - c18_q1))) AS c18_min,
c18_avg,
round(if(c19 != 0, c24 / c19, 0), 2) AS c20,
c21,
c22,
c23 AS c23,
c19 AS c19,
c16 AS c16,
c17 AS c17,
c18 AS c18,
round(c24, 2) AS c24,
round(if(c17 != 0, c24 / c17, 0), 2) AS c25,
'CH' AS c26
FROM
(
SELECT
c1,
c2,
groupUniqArray(c27) AS c28,
groupUniqArrayIf(c27, isNotNull(c29)) AS c28_with_c29,
quantiles(0.25, 0.5, 0.75)(if(c3 > 0, c3, NULL)) AS c3_q,
quantiles(0.25, 0.5, 0.75)(if(c4 > 0, c4, NULL)) AS c4_q,
quantiles(0.25, 0.5, 0.75)(t.c17 / t.c19) AS c5_q,
quantiles(0.25, 0.5, 0.75)(c6) AS c6_q,
quantiles(0.25, 0.5, 0.75)(c7) AS c7_q,
quantiles(0.25, 0.5, 0.75)(c8) AS c8_q,
quantiles(0.25, 0.5, 0.75)(c9) AS c9_q,
quantiles(0.25, 0.5, 0.75)(c10) AS c10_q,
quantiles(0.25, 0.5, 0.75)(c11) AS c11_q,
quantiles(0.25, 0.5, 0.75)(c12) AS c12_q,
quantiles(0.25, 0.5, 0.75)(c13) AS c13_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_q,
quantiles(0.25, 0.5, 0.75)(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_q,
quantiles(0.25, 0.5, 0.75)(t.c16) AS c16_q,
quantiles(0.25, 0.5, 0.75)(t.c17) AS c17_q,
quantiles(0.25, 0.5, 0.75)(if(t.c18 > 0, t.c18, NULL)) AS c18_q,
max(if(c3 > 0, c3, NULL)) AS c3_max,
min(if(c3 > 0, c3, NULL)) AS c3_min,
avg(if(c3 > 0, c3, NULL)) AS c3_avg,
max(if(c4 > 0, c4, NULL)) AS c4_max,
min(if(c4 > 0, c4, NULL)) AS c4_min,
avg(if(c4 > 0, c4, NULL)) AS c4_avg,
max(t.c17 / t.c19) AS c5_max,
min(t.c17 / t.c19) AS c5_min,
avg(t.c17 / t.c19) AS c5_avg,
max(if(c6 > 0, c6, NULL)) AS c6_max,
min(if(c6 > 0, c6, NULL)) AS c6_min,
avg(if(c6 > 0, c6, NULL)) AS c6_avg,
max(if(c7 > 0, c7, NULL)) AS c7_max,
min(if(c7 > 0, c7, NULL)) AS c7_min,
avg(if(c7 > 0, c7, NULL)) AS c7_avg,
max(if(c10 > 0, c10, NULL)) AS c10_max,
min(if(c10 > 0, c10, NULL)) AS c10_min,
avg(if(c10 > 0, c10, NULL)) AS c10_avg,
max(if(c8 > 0, c8, NULL)) AS c8_max,
min(if(c8 > 0, c8, NULL)) AS c8_min,
avg(if(c8 > 0, c8, NULL)) AS c8_avg,
max(if(c9 > 0, c9, NULL)) AS c9_max,
min(if(c9 > 0, c9, NULL)) AS c9_min,
avg(if(c9 > 0, c9, NULL)) AS c9_avg,
max(if(c11 > 0, c11, NULL)) AS c11_max,
min(if(c11 > 0, c11, NULL)) AS c11_min,
avg(if(c11 > 0, c11, NULL)) AS c11_avg,
max(if(c12 > 0, c12, NULL)) AS c12_max,
min(if(c12 > 0, c12, NULL)) AS c12_min,
avg(if(c12 > 0, c12, NULL)) AS c12_avg,
max(if(c13 > 0, c13, NULL)) AS c13_max,
min(if(c13 > 0, c13, NULL)) AS c13_min,
avg(if(c13 > 0, c13, NULL)) AS c13_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c19) AS c14_avg,
max(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_max,
min(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_min,
avg(if(t.c24 > 0, t.c24, NULL) / t.c17) AS c15_avg,
max(t.c16) AS c16_max,
min(t.c16) AS c16_min,
avg(t.c16) AS c16_avg,
max(t.c17) AS c17_max,
min(t.c17) AS c17_min,
avg(t.c17) AS c17_avg,
max(if(t.c18 > 0, t.c18, NULL)) AS c18_max,
min(if(t.c18 > 0, t.c18, NULL)) AS c18_min,
avg(if(t.c18 > 0, t.c18, NULL)) AS c18_avg,
sum(t.c19) AS c19,
sum(if(t.c18 > 0, t.c18, NULL)) AS c18,
sum(t.c16) AS c16,
sum(c23) AS c23,
sum(t.c17) AS c17,
sum(if(t.c24 > 0, t.c24, NULL)) AS c24,
c24 / c19 AS c14,
c24 / c17 AS c15,
median(if(isNotNull(c29) AND (t.c22 > 0), c13 * (t.c22 / c29), NULL)) AS c21,
sum(c22) AS c22
FROM
(
SELECT
c27,
c39 AS c1,
c29,
c19,
c23,
c17,
c16,
c18,
c22,
c24,
c3,
c4,
c8,
c9,
c10,
c11,
c12,
c13,
c6,
c7
FROM
(
SELECT
c27,
uniqExact(c30, c31) AS c19,
uniqExact(c30, c31, c32) AS c23,
uniqExactIf(c30, c31, c33 IN ('c37', 'c38')) AS c17,
countIf(c33 IN ('c37', 'c38')) AS c16,
countIf(c33 = 'c39') AS c18,
coalesce(sumIf(c29, c33 = 'c39'), 0) AS c22,
coalesce(sumIf(c37, c33 = 'c39'), 0) AS c24,
if((c18 > 0) AND (c19 > 0), c18 / c19, NULL) AS c3,
if(c17 != 0, c18 / c17, NULL) AS c4,
coalesce(avgIf(c34, (c34 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c8,
coalesce(avgIf(c35, (c35 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c9,
coalesce(avgIf(c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c10,
coalesce(avgIf(c35, (c35 > 0) AND (c33 = 'c39')), NULL) AS c11,
coalesce(avgIf(c37, c33 = 'c39'), NULL) AS c12,
coalesce(avgIf(c37 / c34, (c34 > 0) AND (c33 = 'c39')), NULL) AS c13,
coalesce(avgIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38'))), NULL) AS c6,
coalesce(minIf(c37, (c37 > 0) AND (c33 IN ('c37', 'c38')) AND (c37 > (c36 / 2))), NULL) AS c7
FROM
(
SELECT
c27,
c30,
c32,
c31,
NULL AS c29,
NULL AS c33,
NULL AS c37,
NULL AS c34,
NULL AS c35
FROM
(
SELECT
c27,
c30,
c32,
c31
FROM database.t1
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE c61 = 0
) AS table25
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c37' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table24
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table23
UNION ALL
SELECT
c27,
c30,
c32,
c31,
c29,
c33,
c37,
c34,
c35
FROM
(
SELECT
c27,
c30,
c32,
'c39' AS c33,
coalesce(c37 * joinGet('database.table18', 'c60', concat(c26, '_', 'CH')), 0) AS c37,
if(c53 > 0, c53, 2) AS c53,
c54,
if(c29 > 0, c29, 1) AS c29,
c55,
c56,
datediff('day', c55, c56) AS c34,
datediff('day', c32, c55) AS c35,
c31
FROM database.table22
PREWHERE ((c32 >= parseDateTimeBestEffort('2020-01-01')) AND (c32 <= parseDateTimeBestEffort('2020-01-01 23:59:59'))) AND (c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
))
WHERE (c61 = 0) AND (c37 < (666 * (1 / joinGet('database.table18', 'c60', concat(c26, '_', 'CH')))))
) AS table21
) AS table20
ALL LEFT JOIN
(
SELECT
c27,
avgMerge(avg_c37) * joinGet('database.table18', 'c60', concat('USD', '_', 'CH')) AS c36
FROM database.table19
PREWHERE c27 IN
(
SELECT comp_c27
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
)
WHERE date > (now() - toIntervalMonth(3))
GROUP BY c27
) AS table17 USING (c27)
GROUP BY c27
) AS table16
ALL LEFT JOIN
(
SELECT
comp_c27 AS c27,
assumeNotNull(c39) AS c39,
c29
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
) USING (c27)
) AS t
ALL LEFT JOIN
(
SELECT
c1,
c2
FROM
(
SELECT
c39 AS c1,
groupArray(comp_c27) AS c49,
multiIf(c1 = 'c58', if(length(c49) <= 2, 0, 1), c1 = 'c57', 1, if(length(c49) <= 3, 0, 1)) AS c2
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
min_c32,
max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38
FROM
(
SELECT
comp_c27,
groupArray(c39) AS c39,
any(c40) AS c40,
any(c41) AS c41,
any(c42) AS c42,
any(c29) AS c29,
any(c43) AS c43,
any(c44) AS c44,
any(min_c32) AS min_c32,
any(max_c32) AS max_c32,
any(c45) AS c45,
any(c46) AS c46,
any(c38) AS c38,
any(c47) AS c47
FROM
(
SELECT
c27 AS comp_c27,
if(comp_c27 = 0, toDate('2010-01-01'), toDate(minMerge(min_c32))) AS min_c32,
if(comp_c27 = 0, toDate(now()), toDate(maxMerge(max_c32))) + 1 AS max_c32,
NULL AS c39,
NULL AS c40,
NULL AS c41,
NULL AS c42,
NULL AS c29,
NULL AS c43,
NULL AS c44,
NULL AS c45,
NULL AS c46,
NULL AS c38,
NULL AS c47
FROM database.table15
GROUP BY comp_c27
UNION ALL
SELECT
comp_c27,
NULL AS min_c32,
NULL AS max_c32,
c39,
c40,
c41,
c42,
c29,
c43,
c44,
c45,
c46,
c38,
c47
FROM
(
SELECT
c39,
comp_c27 AS c27,
comp_c27,
c40,
c41,
assumeNotNull(c45) AS c45,
assumeNotNull(c46) AS c46,
assumeNotNull(c38) AS c38,
joinGet('database.table14', 'c48', c40) AS c42,
joinGet('database.table14', 'c29', c40) AS c29,
joinGet('database.table14', 'c43', c40) AS c43,
joinGet('database.table14', 'property_c44', c40) AS c44,
splitByChar(',', assumeNotNull(joinGet('database.jointable13', 'prefix_c33', comp_c27))) AS c33s,
joinGet('database.jointable13', 'c47', comp_c27) AS c47
FROM
(
SELECT
c39,
comp_c27,
joinGet('database.jointable13', 'c40', comp_c27) AS c40,
c41,
c45,
c46,
c38
FROM
(
SELECT
c39,
arrayJoin(arrayMap(x -> toInt64(x), arrayFilter(x -> (length(x) > 0), splitByString(', ', c49)))) AS comp_c27,
c41,
c45,
c46,
c38
FROM
(
SELECT
'c57' AS c39,
toString(c27) AS c49,
1 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE c27 IN (322)
UNION ALL
SELECT
'c58' AS c39,
arrayStringConcat(groupArray(toString(c27)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table12
WHERE chain_id IN
(
SELECT chain_id
FROM database.table12
WHERE c27 IN (322)
)
UNION ALL
SELECT
'c59' AS c39,
assumeNotNull(c27s_str) AS c49,
0 AS c41,
c50 AS c45,
c51 AS c46,
c52 AS c38
FROM
(
SELECT *
FROM table11
WHERE c27 IN (322)
) AS c1s_c59
WHERE c27 IN (322)
UNION ALL
SELECT
'superSupercalifragilisticexpialidocious' AS c39,
arrayStringConcat(groupArray(toString(c1_id)), ', ') AS c49,
0 AS c41,
'' AS c45,
'' AS c46,
0 AS c38
FROM database.table10
WHERE c27 IN (322)
) AS table9
)
) AS a
) AS table8
) AS table7
GROUP BY comp_c27
) AS table6
WHERE (parseDateTimeBestEffort('2020-01-01') >= min_c32) AND (max_c32 >= (parseDateTimeBestEffort('2021-05-02') - 2))
) AS table5
ARRAY JOIN c39
WHERE isNotNull(c39)
) AS table4
GROUP BY c39
) AS table3
) USING (c1)
GROUP BY
c1,
c2
) AS table2
ORDER BY c1 ASC
) AS table1
FORMAT Null
]]>
</query>
</test>