any
选择列中遇到的第一个值。
默认情况下,该函数从不返回 NULL,即忽略输入列中的 NULL 值。但是,如果该函数与 RESPECT NULLS
修饰符一起使用,则无论是否为 NULL,它都会返回读取的第一个值。
语法
any(column) [RESPECT NULLS]
别名 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
聚合函数中。
示例
查询
CREATE TABLE tab (city Nullable(String)) ENGINE=Memory;
INSERT INTO tab (city) VALUES (NULL), ('Amsterdam'), ('New York'), ('Tokyo'), ('Valencia'), (NULL);
SELECT any(city), anyRespectNulls(city) FROM tab;
┌─any(city)─┬─anyRespectNulls(city)─┐
│ Amsterdam │ ᴺᵁᴸᴸ │
└───────────┴───────────────────────┘