Перейти к основному содержанию
Если вам нужны точные вычисления, особенно при работе с финансовыми или бизнес-данными, требующими высокой точности, стоит использовать Decimal.Числа с плавающей запятой могут давать неточные результаты, как показано ниже:
CREATE TABLE IF NOT EXISTS float_vs_decimal
(
   my_float Float64,
   my_decimal Decimal64(3)
)
ENGINE=MergeTree
ORDER BY tuple();

# Сгенерировать 1 000 000 случайных чисел с 2 знаками после запятой и сохранить их как float и как decimal
INSERT INTO float_vs_decimal SELECT round(randCanonical(), 3) AS res, res FROM system.numbers LIMIT 1000000;
SELECT sum(my_float), sum(my_decimal) FROM float_vs_decimal;

┌──────sum(my_float)─┬─sum(my_decimal)─┐
499693.60500000004499693.605
└────────────────────┴─────────────────┘

SELECT sumKahan(my_float), sumKahan(my_decimal) FROM float_vs_decimal;

┌─sumKahan(my_float)─┬─sumKahan(my_decimal)─┐
499693.605499693.605
└────────────────────┴──────────────────────┘
Эквивалентные типы в ClickHouse и C приведены ниже:
  • Float32float.
  • Float64double.
Типы с плавающей запятой в ClickHouse имеют следующие псевдонимы:
  • Float32FLOAT, REAL, SINGLE.
  • Float64DOUBLE, DOUBLE PRECISION.
При создании таблиц можно задавать числовые параметры для чисел с плавающей запятой (например, FLOAT(12), FLOAT(15, 22), DOUBLE(12), DOUBLE(4, 18)), но ClickHouse их игнорирует.

Использование чисел с плавающей запятой

  • При вычислениях с числами с плавающей запятой может возникать ошибка округления.
SELECT 1 - 0.9

┌───────minus(1, 0.9)─┐
0.09999999999999998
└─────────────────────┘
  • Результат вычислений зависит от способа вычислений (типа процессора и архитектуры компьютерной системы).
  • Вычисления с числами с плавающей запятой могут давать такие значения, как бесконечность (Inf) и «не число» (NaN). Это следует учитывать при обработке результатов вычислений.
  • При разборе чисел с плавающей запятой из текста результат может не быть ближайшим числом, представимым в машинном формате.

NaN и Inf

В отличие от стандартного SQL, ClickHouse поддерживает следующие категории чисел с плавающей запятой:
  • Inf — бесконечность.
SELECT 0.5 / 0

┌─divide(0.5, 0)─┐
│            inf │
└────────────────┘
  • -Inf — Отрицательная бесконечность.
SELECT -0.5 / 0

┌─divide(-0.5, 0)─┐
-inf │
└─────────────────┘
  • NaN — не является числом.
SELECT 0 / 0

┌─divide(0, 0)─┐
│          nan │
└──────────────┘
Правила сортировки NaN см. в разделе предложение ORDER BY.

BFloat16

BFloat16 — это 16-битный тип данных с плавающей запятой с 8-битными экспонентой и знаком, а также 7-битной мантиссой. Он полезен для приложений машинного обучения и ИИ. ClickHouse поддерживает преобразования между Float32 и BFloat16, которые можно выполнять с помощью функций toFloat32() или toBFloat16.
Большинство других операций не поддерживается.
Последнее изменение 10 июня 2026 г.