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

Функции quantileExact

quantileExact

Появилось в: v1.1

Точно вычисляет квантиль числовой последовательности данных.

Чтобы получить точное значение, все переданные значения объединяются в массив, который затем частично сортируется. Поэтому функция потребляет O(n) памяти, где n — количество переданных значений. Однако при небольшом количестве значений функция работает очень эффективно.

При использовании нескольких функций quantile* с разными уровнями в запросе их внутренние состояния не объединяются (то есть запрос работает менее эффективно, чем мог бы). В этом случае используйте функцию quantiles.

Синтаксис

quantileExact(level)(expr)

Псевдонимы: medianExact

Параметры

  • level — Необязательный параметр. Уровень квантиля. Константное число с плавающей запятой от 0 до 1. Рекомендуется использовать значение level в диапазоне [0.01, 0.99]. Значение по умолчанию: 0.5. При level=0.5 функция вычисляет медиану. Float*

Аргументы

  • expr — Выражение над значениями столбца, которое возвращает числовые типы данных, Date или DateTime. (U)Int* или Float* или Decimal* или Date или DateTime

Возвращаемое значение

Квантиль указанного уровня. Для числовых типов данных формат вывода совпадает с форматом входных данных. (U)Int* или Float* или Decimal* или Date или DateTime

Примеры

Вычисление точного квантиля

SELECT quantileExact(number) FROM numbers(10);
┌─quantileExact(number)─┐
│                     5 │
└───────────────────────┘

См. также