count_if
聚合函數
適用於:Databricks SQL Databricks Runtime
返回 expr
中屬於該群組的 true values 數目。
語法
count_if ( [ALL | DISTINCT] expr ) [ FILTER ( WHERE cond ) ]
您可以將此函式叫用為 window 函式,並使用 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