Агрегатная функция 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