184 похожих чатов

Привет есть следующая таблица: ``` create table traffic ( did

UInt64,
....
report_date Date,
country_code LowCardinality(String)
)
engine = ReplicatedMergeTree('/clickhouse/tables/{shard}/reports_v0/traffic', '{replica}')
PARTITION BY toStartOfMonth(report_date)
ORDER BY (did, country_code)
SETTINGS index_granularity = 512;
```
Делаю вот такой запрос
```
with ids as (
select c.cid did, alpha2 country_code
from reports_v0.competitors c
join reports_v0.iso2_locations l on l.alpha2 = c.country_code
prewhere c.did = cityHash64('google.com')
group by did, country_code
)
select sum(total_traffic)
from reports_v0.traffic t
prewhere did in (select ids.did from ids)
and report_date = '2022-04-01'
and country_code = 'US';
```
В логах следующее:
```
Selected 2/79 parts by partition key, 2 parts by primary key, 2779/15452 marks by primary key, 2779 marks to read from 2283 ranges
...
Read 1422477 rows
```
При этом всего строк 468 (если sum(total_traffic) заменить на count(1)). В cte ids 10911 строк.
Почему прочитано 1422477 строк (2779 * 512). Должно же быть в худшем случае 468 * 512 = 239616?

UPD: сам спросил, сам ответил)) Должно быть даже больше 10911 * 512 ~ 5 лямов в худшем случае))

1 ответов

25 просмотров

Функция count не читает файлы с жесткого диска, она обращается к PK, как я помню

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта