count_if 集計関数

適用対象: 「はい」のチェック マーク 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