count_if 聚合函数

适用于:check marked yes Databricks SQL check marked yes 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