2017-12-11 12:07:26 +00:00
|
|
|
|
# Условные функции
|
2017-03-12 17:58:51 +00:00
|
|
|
|
|
2017-12-11 12:07:26 +00:00
|
|
|
|
## if(cond, then, else), оператор cond ? then : else
|
2018-07-26 14:41:59 +00:00
|
|
|
|
|
|
|
|
|
Возвращает `then`, если `cond != 0` или `else`, если `cond = 0`.
|
|
|
|
|
`cond` должно иметь тип `UInt8`, а `then` и `else` должны иметь тип, для которого есть наименьший общий тип.
|
|
|
|
|
|
|
|
|
|
`then` и `else` могут быть `NULL`
|
|
|
|
|
|
|
|
|
|
## multiIf
|
|
|
|
|
|
2018-08-10 14:44:49 +00:00
|
|
|
|
Позволяет более компактно записать оператор [CASE](../operators.md#operator_case) в запросе.
|
2018-07-26 14:41:59 +00:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
multiIf(cond_1, then_1, cond_2, then_2...else)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
**Параметры**
|
|
|
|
|
|
|
|
|
|
- `cond_N` — Условие, при выполнении которого функция вернёт `then_N`.
|
|
|
|
|
- `then_N` — Результат функции при выполнении.
|
|
|
|
|
- `else` — Результат функции, если ни одно из условий не выполнено.
|
|
|
|
|
|
|
|
|
|
Функция принимает `2N+1` параметров.
|
|
|
|
|
|
|
|
|
|
**Возвращаемые значения**
|
|
|
|
|
|
|
|
|
|
Функция возвращает одно из значений `then_N` или `else`, в зависимости от условий `cond_N`.
|
|
|
|
|
|
|
|
|
|
**Пример**
|
|
|
|
|
|
|
|
|
|
Рассмотрим таблицу
|
|
|
|
|
|
2019-09-23 15:31:46 +00:00
|
|
|
|
```text
|
2018-07-26 14:41:59 +00:00
|
|
|
|
┌─x─┬────y─┐
|
|
|
|
|
│ 1 │ ᴺᵁᴸᴸ │
|
|
|
|
|
│ 2 │ 3 │
|
|
|
|
|
└───┴──────┘
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Выполним запрос `SELECT multiIf(isNull(y), x, y < 3, y, NULL) FROM t_null`. Результат:
|
|
|
|
|
|
2019-09-23 15:31:46 +00:00
|
|
|
|
```text
|
2018-07-26 14:41:59 +00:00
|
|
|
|
┌─multiIf(isNull(y), x, less(y, 3), y, NULL)─┐
|
|
|
|
|
│ 1 │
|
|
|
|
|
│ ᴺᵁᴸᴸ │
|
|
|
|
|
└────────────────────────────────────────────┘
|
|
|
|
|
```
|
2018-10-16 10:47:17 +00:00
|
|
|
|
|
2020-01-30 10:34:55 +00:00
|
|
|
|
[Оригинальная статья](https://clickhouse.tech/docs/ru/query_language/functions/conditional_functions/) <!--hide-->
|