Перейти к основному содержанию

quantileTimingWeighted

Добавленный в: v1.1.0 С заданной точностью вычисляет квантиль последовательности числовых данных с учетом веса каждого элемента последовательности. Результат детерминирован (не зависит от порядка обработки запроса). Функция оптимизирована для работы с последовательностями, описывающими распределения, такие как время загрузки веб-страниц или время отклика backend-соединения. При использовании в одном запросе нескольких функций quantile* с разными уровнями внутренние состояния не объединяются (то есть запрос выполняется менее эффективно, чем мог бы). В этом случае используйте функцию quantiles. Точность Вычисление является точным, если:
  • Общее количество значений не превышает 5670.
  • Общее количество значений превышает 5670, но время загрузки страницы меньше 1024 мс.
В противном случае результат вычисления округляется до ближайшего значения, кратного 16 мс.
Для вычисления квантилей времени загрузки страницы эта функция эффективнее и точнее, чем quantile.
Если в функцию не переданы значения (при использовании quantileTimingIf), возвращается NaN. Это сделано для того, чтобы отличать такие случаи от случаев, в которых результат равен нулю. Примечания о сортировке значений NaN см. в разделе предложение ORDER BY.
Синтаксис
quantileTimingWeighted(level)(expr, weight)
Псевдонимы: medianTimingWeighted Параметры
  • level — Необязательный. Уровень квантиля. Константное число с плавающей запятой от 0 до 1. Рекомендуется использовать значение level в диапазоне [0.01, 0.99]. Значение по умолчанию: 0.5. При level=0.5 функция вычисляет медиану. Float*
Аргументы
  • expr — Выражение над значениями столбца, возвращающее число типа Float*. Если в функцию передаются отрицательные значения, поведение не определено. Если значение превышает 30 000 (время загрузки страницы более 30 секунд), считается, что оно равно 30 000. Float*
  • weight — Столбец с весами элементов последовательности. Вес — это количество вхождений значения. UInt*
Возвращаемое значение Квантиль указанного уровня. Float32 Примеры Вычисление взвешенного квантиля времени
Query
CREATE TABLE t (response_time UInt32, weight UInt32) ENGINE = Memory;
INSERT INTO t VALUES (68, 1), (104, 2), (112, 3), (126, 2), (138, 1), (162, 1);

SELECT quantileTimingWeighted(response_time, weight) FROM t;
Response
┌─quantileTimingWeighted(response_time, weight)─┐
│                                           112 │
└───────────────────────────────────────────────┘
Последнее изменение 10 июня 2026 г.