> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-fix-nav-issues.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# countIf

> Exemplo de uso do combinador countIf

<div id="description">
  ## Descrição
</div>

O combinador [`If`](/pt-BR/reference/functions/aggregate-functions/combinators#-if) pode ser aplicado à função [`count`](/pt-BR/reference/functions/aggregate-functions/count)
para contar o número de linhas em que a condição é verdadeira,
usando a função de combinador de agregação `countIf`.

<div id="example-usage">
  ## Exemplo de uso
</div>

Neste exemplo, vamos criar uma tabela que armazena tentativas de login de usuários
e usar `countIf` para contar o número de logins bem-sucedidos.

```sql title="Query" theme={null}
CREATE TABLE login_attempts(
    user_id UInt32,
    timestamp DateTime,
    is_successful UInt8
) ENGINE = MergeTree
ORDER BY ();

INSERT INTO login_attempts VALUES
    (1, '2024-01-01 10:00:00', 1),
    (1, '2024-01-01 10:05:00', 0),
    (1, '2024-01-01 10:10:00', 1),
    (2, '2024-01-01 11:00:00', 1),
    (2, '2024-01-01 11:05:00', 1),
    (2, '2024-01-01 11:10:00', 0);

SELECT
    user_id,
    countIf(is_successful = 1) AS successful_logins
FROM login_attempts
GROUP BY user_id;
```

A função `countIf` contará apenas as linhas em que `is_successful = 1` para cada usuário.

```response title="Response" theme={null}
   ┌─user_id─┬─successful_logins─┐
1. │       1 │                 2 │
2. │       2 │                 2 │
   └─────────┴───────────────────┘
```

<div id="see-also">
  ## Veja também
</div>

* [`count`](/pt-BR/reference/functions/aggregate-functions/count)
* [`If combinador`](/pt-BR/reference/functions/aggregate-functions/combinators#-if)
