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

Добрый день. Ради интереса замерил время выполнения запросов. Использовал данный

датасет для тестов https://clickhouse.com/docs/en/getting-started/example-datasets/amazon-reviews. Использовал клик-облако.
Посчитал кол-во уников в поле 3мя запросами:
1) SELECT
count(distinct product_category)
from amazon_reviews

2) select
count()
from (
SELECT
product_category
from amazon_reviews
GROUP BY product_category
)t1


3) SELECT
uniq(product_category)
from amazon_reviews

Так же приложил скрины с оценкой времени(при разных запусках не сильно отличается). Почему второй запрос работает быстрее? Если есть в доках описанный момент - буду благодарен за ссылку

6 ответов

26 просмотров

ну ... для начала было бы не плохо результаты на clickhouse-client показать во вторых, второй запрос может работать значительно быстрее после первого. потому что вся колонка product_category фактически подтягивается в linux page cache так что у вас явно проблемы с замерами

Ω- Автор вопроса
Slach [altinity]
ну ... для начала было бы не плохо результаты на c...

1. почему нужно сначала на клиенте посмотреть рез-ты? 2. пробовал перезайти на консоль облака и ребут компа. пробовал 2й запрос так же запустить первым

Ω
1. почему нужно сначала на клиенте посмотреть рез-...

1. на клиенте запущеном на том же сервере, чтобы быть уверенными что сетевые задержки не влияют 2. смотрите system.query_log для ваших запросов в ProfileEvents поле... смотрите по каким событиям разница больше всего

ответы здесь https://kb.altinity.com/altinity-kb-queries-and-syntax/distinct-vs-group-by-vs-limit-by/

Ω- Автор вопроса

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

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

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
Есть сайт. Там была древняя версия эво. Стоял плагин, который каждый коммент в Jot делал отдельной страницей. После обновления все слетело, теперь старница открывается отдельн...
Artem
1
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
Добрый день. А shovel'ы можно как-то сконфигурировать в definitions.json? Пробовал что-то вроде: { "users": [ { "name": "agent", "password_hash": "RBCbTzQd...
Aleksey
1
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Карта сайта