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;


create table competitors
(
did UInt64,
cid UInt64,
competition_level Float64,
country_code LowCardinality(String)
)
engine = ReplicatedMergeTree('/clickhouse/tables/{shard}/reports_v0/competitors', '{replica}')
ORDER BY (did, country_code)
SETTINGS index_granularity = 16384;
```
Запрос:
```
select distinct domain_name
from reports_v0.traffic t inner join (
select c.cid, max(c.competition_level) level from reports_v0.competitors c
prewhere c.did = cityHash64('google.com')
and c.cid != cityHash64('google.com')
group by c.cid
having level > 0
limit 100
) as s1 on t.did = s1.cid
order by s1.level desc;
```

Смотрю в логах и вижу, что сперва сканится левая таблица traffic.
Судя по документации сперва должна формироваться правая таблица, то есть подзапрос (тем более там всего 100 строк). Но в действительности все иначе почему?
join_algorithm = 'hash'

2 ответов

15 просмотров

Каким образом вы видите в логах что это не так? Сообщения про то сколько строк будет прочитано из левой, не считаются, они до выполнения реальной работы.

last seen recently 🇹🇼- Автор вопроса
Denny [Altinity]
Каким образом вы видите в логах что это не так? С...

<Debug> reports_v0.traffic (7a3d90a4-abd9-4b40-ba3d-90a4abd99b40) (SelectExecutor): Key condition: unknown <Debug> reports_v0.traffic (7a3d90a4-abd9-4b40-ba3d-90a4abd99b40) (SelectExecutor): Selected 79/79 parts by partition key, 79 parts by primary key, 609223/609223 marks by primary key, 609223 marks to read from 79 ranges <Debug> reports_v0.traffic (7a3d90a4-abd9-4b40-ba3d-90a4abd99b40) (SelectExecutor): Reading approx. 311636945 rows with 4 streams (всего в таблице как раз таки 311636945 строк) .... <Information> executeQuery: Read 311702481 rows, 9.25 GiB in 2.699349693 sec., 115473175 rows/sec., 3.43 GiB/sec. Elapsed: 2.700 sec. Processed 311.70 million rows

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

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

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
День добрый, подскажите пожалуйста, есть ли какой-то способ сказать ребару не компилировать определённое приложение? Всю доку их перечиатл ничего подобного не нашёл
Кирилл
14
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
10
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
Карта сайта