2020-10-26 10:29:30 +00:00
---
2022-04-09 13:29:05 +00:00
sidebar_position: 34
sidebar_label: "Арифметические функции"
2020-10-26 10:29:30 +00:00
---
2020-03-20 18:20:59 +00:00
# Арифметические функции {#arifmeticheskie-funktsii}
2017-03-12 17:58:51 +00:00
2020-03-20 18:20:59 +00:00
Для всех арифметических функций, тип результата вычисляется, как минимальный числовой тип, который может вместить результат, если такой тип есть. Минимум берётся одновременно по числу бит, знаковости и «плавучести». Если бит не хватает, то берётся тип максимальной битности.
2017-03-12 17:58:51 +00:00
Пример:
2020-03-20 18:20:59 +00:00
``` sql
2017-10-25 05:27:09 +00:00
SELECT toTypeName(0), toTypeName(0 + 0), toTypeName(0 + 0 + 0), toTypeName(0 + 0 + 0 + 0)
```
2017-03-12 17:58:51 +00:00
2020-03-20 18:20:59 +00:00
``` text
2017-10-25 05:27:09 +00:00
┌─toTypeName(0)─┬─toTypeName(plus(0, 0))─┬─toTypeName(plus(plus(0, 0), 0))─┬─toTypeName(plus(plus(plus(0, 0), 0), 0))─┐
│ UInt8 │ UInt16 │ UInt32 │ UInt64 │
└───────────────┴────────────────────────┴─────────────────────────────────┴──────────────────────────────────────────┘
```
2017-06-13 04:15:47 +00:00
2017-03-12 17:58:51 +00:00
Арифметические функции работают для любой пары типов из UInt8, UInt16, UInt32, UInt64, Int8, Int16, Int32, Int64, Float32, Float64.
Переполнение производится также, как в C++.
2020-03-20 18:20:59 +00:00
## plus(a, b), оператор a + b {#plusa-b-operator-a-b}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет сумму чисел.
Также можно складывать целые числа с датой и датой-с -временем. В случае даты, прибавление целого числа означает прибавление соответствующего количества дней. В случае даты-с -временем - прибавление соответствующего количества секунд.
2020-03-20 18:20:59 +00:00
## minus(a, b), оператор a - b {#minusa-b-operator-a-b}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет разность чисел. Результат всегда имеет знаковый тип.
Также можно вычитать целые числа из даты и даты-с -временем. Смысл аналогичен - смотрите выше для plus.
2020-03-20 18:20:59 +00:00
## multiply(a, b), оператор a \* b {#multiplya-b-operator-a-b}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет произведение чисел.
2020-03-20 18:20:59 +00:00
## divide(a, b), оператор a / b {#dividea-b-operator-a-b}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет частное чисел. Тип результата всегда является типом с плавающей запятой.
Т о есть, деление не целочисленное. Для целочисленного деления, используйте функцию intDiv.
При делении на ноль получится inf, -inf или nan.
2020-03-20 18:20:59 +00:00
## intDiv(a, b) {#intdiva-b}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет частное чисел. Деление целочисленное, с округлением вниз (по абсолютному значению).
При делении на ноль или при делении минимального отрицательного числа на минус единицу, кидается исключение.
2020-03-20 18:20:59 +00:00
## intDivOrZero(a, b) {#intdivorzeroa-b}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Отличается от intDiv тем, что при делении на ноль или при делении минимального отрицательного числа на минус единицу, возвращается ноль.
2020-05-19 06:02:30 +00:00
## modulo(a, b), оператор a % b {#modulo}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет остаток от деления.
Если аргументы - числа с плавающей запятой, то они предварительно преобразуются в целые числа, путём отбрасывания дробной части.
Берётся остаток в том же смысле, как это делается в C++. По факту, для отрицательных чисел, используется truncated division.
При делении на ноль или при делении минимального отрицательного числа на минус единицу, кидается исключение.
2020-05-19 06:02:30 +00:00
## moduloOrZero(a, b) {#modulo-or-zero}
В отличие от [modulo ](#modulo ), возвращает ноль при делении на ноль.
2020-03-20 18:20:59 +00:00
## negate(a), оператор -a {#negatea-operator-a}
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Вычисляет число, обратное по знаку. Результат всегда имеет знаковый тип.
2020-03-22 09:14:59 +00:00
## abs(a) {#arithm_func-abs}
2017-10-25 05:27:09 +00:00
2020-03-20 18:20:59 +00:00
Вычисляет абсолютное значение для числа a. Т о есть, если a \< 0, то возвращает -a.
2017-03-12 17:58:51 +00:00
Для беззнаковых типов ничего не делает. Для чисел типа целых с о знаком, возвращает число беззнакового типа.
2017-11-23 08:46:51 +00:00
2020-03-20 18:20:59 +00:00
## gcd(a, b) {#gcda-b}
2017-11-23 08:46:51 +00:00
Вычисляет наибольший общий делитель чисел.
При делении на ноль или при делении минимального отрицательного числа на минус единицу, кидается исключение.
2020-03-20 18:20:59 +00:00
## lcm(a, b) {#lcma-b}
2017-11-23 08:46:51 +00:00
Вычисляет наименьшее общее кратное чисел.
При делении на ноль или при делении минимального отрицательного числа на минус единицу, кидается исключение.
2018-10-16 10:47:17 +00:00
2021-10-22 14:57:55 +00:00
## max2 {#max2}
2021-10-24 08:10:00 +00:00
Сравнивает два числа и возвращает максимум. Возвращаемое значение приводится к типу [Float64 ](../../sql-reference/data-types/float.md ).
2021-10-22 14:57:55 +00:00
**Синтаксис**
```sql
max2(value1, value2)
```
**Аргументы**
- `value1` — первое число. [Int/UInt ](../../sql-reference/data-types/int-uint.md ) или [Float ](../../sql-reference/data-types/float.md ).
- `value2` — второе число. [Int/UInt ](../../sql-reference/data-types/int-uint.md ) или [Float ](../../sql-reference/data-types/float.md ).
**Возвращаемое значение**
- Максимальное значение среди двух чисел.
Тип: [Float ](../../sql-reference/data-types/float.md ).
**Пример**
Запрос:
```sql
SELECT max2(-1, 2);
```
Результат:
```text
┌─max2(-1, 2)─┐
│ 2 │
└─────────────┘
```
## min2 {#min2}
2021-10-24 08:10:00 +00:00
Сравнивает два числа и возвращает минимум. Возвращаемое значение приводится к типу [Float64 ](../../sql-reference/data-types/float.md ).
2021-10-22 14:57:55 +00:00
**Синтаксис**
```sql
min2(value1, value2)
```
**Аргументы**
- `value1` — первое число. [Int/UInt ](../../sql-reference/data-types/int-uint.md ) или [Float ](../../sql-reference/data-types/float.md ).
- `value2` — второе число. [Int/UInt ](../../sql-reference/data-types/int-uint.md ) или [Float ](../../sql-reference/data-types/float.md ).
**Возвращаемое значение**
- Минимальное значение среди двух чисел.
Тип: [Float ](../../sql-reference/data-types/float.md ).
**Пример**
Запрос:
```sql
SELECT min2(-1, 2);
```
Результат:
```text
┌─min2(-1, 2)─┐
│ -1 │
└─────────────┘
```