適用対象:
Databricks SQL
Databricks Runtime
expr 内のグループの true の値の数を返します。
構文
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