any
选择某一列的第一个遇到的值。
默认情况下,函数永远不会返回 NULL,也就是说,忽略输入列中的 NULL 值。
然而,如果函数与 RESPECT NULLS
修饰符一起使用,它将返回第一个读取的值,无论其是否为 NULL。
语法
别名 any(column)
(不带 RESPECT NULLS
)
any_value
first_value
。
any(column) RESPECT NULLS
的别名
anyRespectNulls
,any_respect_nulls
firstValueRespectNulls
,first_value_respect_nulls
anyValueRespectNulls
,any_value_respect_nulls
参数
column
: 列名。
返回值
第一个遇到的值。
备注
该函数的返回类型与输入相同,除了 LowCardinality 被丢弃。
这意味着如果没有行作为输入,它将返回该类型的默认值(对于整数为0,或者对于 Nullable() 列为 Null)。
您可以使用 -OrNull
组合器 来修改此行为。
实现细节
在某些情况下,您可以依赖执行顺序。
这适用于 SELECT
来自使用 ORDER BY
的子查询的情况。
当一个 SELECT
查询具有 GROUP BY
子句或至少一个聚合函数时,ClickHouse(与 MySQL 不同)要求 SELECT
、HAVING
和 ORDER BY
子句中的所有表达式必须从键或聚合函数中计算得出。
换句话说,从表中选择的每一列必须在键中使用或在聚合函数内部使用。
要获得类似于 MySQL 的行为,您可以将其他列放入 any
聚合函数中。
示例
查询: