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

quantileExactWeighted

Добавленный в: v1.1.0 Точно вычисляет квантиль числовой последовательности с учетом веса каждого элемента. Чтобы получить точное значение, все переданные значения объединяются в массив, который затем частично сортируется. Каждое значение учитывается с соответствующим весом, как будто оно встречается weight раз. В алгоритме используется хеш-таблица. Поэтому, если переданные значения часто повторяются, функция потребляет меньше оперативной памяти, чем quantileExact. Эту функцию можно использовать вместо quantileExact, указав вес 1. При использовании в запросе нескольких функций quantile* с разными уровнями внутренние состояния не объединяются (то есть запрос работает менее эффективно, чем мог бы). В этом случае используйте функцию quantiles. Синтаксис
quantileExactWeighted(level)(expr, weight)
Псевдонимы: medianExactWeighted Параметры
  • level — Необязательный параметр. Уровень квантиля. Константное число с плавающей точкой в диапазоне от 0 до 1. Рекомендуется использовать значение level в диапазоне [0.01, 0.99]. Значение по умолчанию: 0.5. При level=0.5 функция вычисляет медиану. Float*
Аргументы
  • expr — Выражение над значениями столбца, результатом которого является числовой тип данных, Date или DateTime. (U)Int* или Float* или Decimal* или Date или DateTime
  • weight — Столбец с весами элементов последовательности. Вес — это количество вхождений значения. UInt*
Возвращаемое значение Квантиль указанного уровня. Float64 или Date или DateTime Примеры Вычисление точного взвешенного квантиля
Query
CREATE TABLE t (
    n Int32,
    val Int32
) ENGINE = Memory;

-- Вставить тестовые данные
INSERT INTO t VALUES
(0, 3),
(1, 2),
(2, 1),
(5, 4);

SELECT quantileExactWeighted(n, val) FROM t;
Response
┌─quantileExactWeighted(n, val)─┐
│                             1 │
└───────────────────────────────┘
См. также
Последнее изменение 10 июня 2026 г.