count_if 聚合函數

適用於:check marked yes Databricks SQL check marked yes Databricks Runtime

傳回 中 expr群組的 true 值數目。

語法

count_if ( [ALL | DISTINCT] expr ) [ FILTER ( WHERE cond ) ]

您也可以使用 子句,將此函式叫用OVER視窗函式。

引數

  • expr:布爾表達式。
  • 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