2017-12-11 12:07:26 +00:00
# Функции округления
2017-03-12 17:58:51 +00:00
2017-12-11 12:07:26 +00:00
## floor(x\[, N\])
2017-03-12 17:58:51 +00:00
Возвращает наибольшее круглое число, которое меньше или равно, чем x.
Круглым называется число, кратное 1 / 10N или ближайшее к нему число соответствующего типа данных, если 1 / 10N не представимо точно.
N - целочисленная константа, не обязательный параметр. По умолчанию - ноль, что означает - округлять до целого числа.
N может быть отрицательным.
2017-10-25 05:27:09 +00:00
Примеры: `floor(123.45, 1) = 123.4, floor(123.45, -1) = 120.`
2017-03-12 17:58:51 +00:00
2017-10-25 05:27:09 +00:00
`x` - любой числовой тип. Результат - число того же типа.
2017-03-12 17:58:51 +00:00
Для целочисленных аргументов имеет смысл округление с отрицательным значением N (для неотрицательных N, функция ничего не делает).
В случае переполнения при округлении (например, floor(-128, -1)), возвращается implementation specific результат.
2017-12-11 12:07:26 +00:00
## ceil(x\[, N\])
2017-03-12 17:58:51 +00:00
Возвращает наименьшее круглое число, которое больше или равно, чем x.
В остальном, аналогично функции floor, см. выше.
2017-12-11 12:07:26 +00:00
## round(x\[, N\])
2018-08-15 10:56:54 +00:00
Реализует [банковское округление ](https://en.wikipedia.org/wiki/Rounding#Round_half_to_even ), т.е . округление до ближайшего чётного.
2018-08-22 06:18:29 +00:00
**Аргументы функции**
2018-08-15 10:56:54 +00:00
- `x` — число для округления. [Тип ](../../data_types/index.md#data_types ) — любой числовой.
- `N` — позиция цифры после запятой, до которой следует округлять.
**Возвращаемое значение**
Округлённое число того же типа, что и входное число `x` .
**Пример**
2018-10-16 10:47:17 +00:00
``` sql
2018-08-15 10:56:54 +00:00
SELECT
number / 2 AS x,
round(x)
FROM system.numbers
LIMIT 10
2018-08-16 08:25:35 +00:00
```
```
2018-08-15 10:56:54 +00:00
┌───x─┬─round(divide(number, 2))─┐
│ 0 │ 0 │
│ 0.5 │ 0 │
│ 1 │ 1 │
│ 1.5 │ 2 │
│ 2 │ 2 │
│ 2.5 │ 2 │
│ 3 │ 3 │
│ 3.5 │ 4 │
│ 4 │ 4 │
│ 4.5 │ 4 │
└─────┴──────────────────────────┘
```
2017-03-12 17:58:51 +00:00
2017-12-11 12:07:26 +00:00
## roundToExp2(num)
2017-03-12 17:58:51 +00:00
Принимает число. Если число меньше единицы - возвращает 0. Иначе округляет число вниз до ближайшей (целой неотрицательной) степени двух.
2017-12-11 12:07:26 +00:00
## roundDuration(num)
2017-03-12 17:58:51 +00:00
Принимает число. Если число меньше единицы - возвращает 0. Иначе округляет число вниз до чисел из набора: 1, 10, 30, 60, 120, 180, 240, 300, 600, 1200, 1800, 3600, 7200, 18000, 36000. Эта функция специфична для Яндекс.Метрики и предназначена для реализации отчёта по длительности визита.
2017-12-11 12:07:26 +00:00
## roundAge(num)
2017-05-15 18:26:46 +00:00
Принимает число. Если число меньше 18 - возвращает 0. Иначе округляет число вниз до чисел из набора: 18, 25, 35, 45, 55. Эта функция специфична для Яндекс.Метрики и предназначена для реализации отчёта по возрасту посетителей.
2018-10-16 10:47:17 +00:00
[Оригинальная статья ](https://clickhouse.yandex/docs/ru/query_language/functions/rounding_functions/ ) <!--hide-->