Агрегатная функция count_if
Область применения: Databricks SQL
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