ClickHouse/docs/zh/query_language/functions/conditional_functions.md
2019-06-07 13:40:49 +03:00

1.4 KiB
Raw Blame History

条件函数

if(cond, then, else), cond ? operator then : else

如果cond = 0则返回then,如果cond = 0则返回elsecond必须是UInt8类型,thenelse必须存在最低的共同类型。

thenelse可以是NULL

multiIf

允许您在查询中更紧凑地编写CASE运算符。

multiIf(cond_1, then_1, cond_2, then_2...else)

参数:

  • cond_N — 函数返回then_N的条件。
  • then_N — 执行时函数的结果。
  • else — 如果没有满足任何条件,则为函数的结果。

该函数接受2N + 1参数。

返回值

该函数返回值“then_N”或“else”之一具体取决于条件cond_N

示例

存在如下一张表

┌─x─┬────y─┐
│ 1 │ ᴺᵁᴸᴸ │
│ 2 │    3 │
└───┴──────┘

执行查询 SELECT multiIf(isNull(y) x, y < 3, y, NULL) FROM t_null。结果:

┌─multiIf(isNull(y), x, less(y, 3), y, NULL)─┐
│                                          1 │
│                                       ᴺᵁᴸᴸ │
└────────────────────────────────────────────┘

来源文章