В ClickHouse у таблицы `events` 10 ТБ данных, PARTITION BY toYYYYMM(date). Нужно посчитать события за последние 7 дней. Что выполнится быстрее?
SQLhardsenior
Варианты ответа
WHERE date >= today() - 7 — partition pruning откинет старые месяцы, Clickhouse прочитает только текущую и предыдущую партицию с min-max индексом по дате внутри
WHERE toStartOfDay(date) BETWEEN today() - 7 AND today() — функция-обёртка помогает оптимизатору лучше распознать диапазон и применить более агрессивный partition pruning
WHERE formatDateTime(date, '%Y-%m-%d') >= '2026-04-17' — явное преобразование к строке даёт прямое сравнение лексикографически, быстрее чем работа с датами
WHERE toString(date) LIKE '2026-04-%' — строковое сравнение использует bloom-filter индекс ClickHouse и пропускает блоки без совпадений, это эффективнее прямого сравнения
Разбор ответа
Подробный разбор с объяснением «почему правильный ответ верный» и почему остальные неверны — после регистрации.
2475 вопросов с разбором, quiz-режим с проверкой, AI-собес и подготовка к интервью аналитика.