count_if
聚合函数
适用于: Databricks SQL Databricks Runtime
返回 expr
中组的真实值数。
语法
count_if ( [ALL | DISTINCT] expr ) [ FILTER ( WHERE cond ) ]
还可以使用 OVER
子句将此函数作为窗口函数调用。
参数
expr
:一个 BOOLEAN 表达式。cond
:一个可选的布尔表达式,可筛选用于聚合的行。
返回
一个 BIGINT
。
count_if(expr) FILTER(WHERE cond)
等效于 count_if(expr AND cond)
。
如果指定 DISTINCT
,则只对唯一行进行计数。
示例
> SELECT count_if(col % 2 = 0) FROM VALUES (NULL), (0), (1), (2), (2), (3) AS tab(col);
3
> SELECT count_if(DISTINCT col % 2 = 0) FROM VALUES (NULL), (0), (1), (2), (2), (3) AS tab(col);
2
> SELECT count_if(col IS NULL) FROM VALUES (NULL), (0), (1), (2), (3) AS tab(col);
1