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

> Calcula a soma dos números, usando para o resultado o mesmo tipo de dado dos parâmetros de entrada. Se a soma exceder o valor máximo desse tipo de dado, ela será calculada com overflow.

# sumWithOverflow

<div id="sumWithOverflow">
  ## sumWithOverflow
</div>

Introduzido em: v1.1.0

Calcula a soma de valores numéricos usando, no resultado, o mesmo tipo de dado dos parâmetros de entrada.
Se a soma exceder o valor máximo desse tipo de dado, ela será calculada com overflow.

**Sintaxe**

```sql theme={null}
sumWithOverflow(num)
```

**Argumentos**

* `num` — Coluna com valores numéricos. [`(U)Int*`](/pt-BR/reference/data-types/int-uint) ou [`Float*`](/pt-BR/reference/data-types/float) ou [`Decimal*`](/pt-BR/reference/data-types/decimal)

**Valor retornado**

A soma dos valores. [`(U)Int*`](/pt-BR/reference/data-types/int-uint) ou [`Float*`](/pt-BR/reference/data-types/float) ou [`Decimal*`](/pt-BR/reference/data-types/decimal)

**Exemplos**

**Demonstrando o comportamento de overflow com UInt16**

```sql title=Query theme={null}
CREATE TABLE employees
(
    id UInt32,
    name String,
    monthly_salary UInt16 -- selecionado para que a soma dos valores produza um overflow
)
ENGINE = Memory;

INSERT INTO employees VALUES
    (1, 'John', 20000),
    (2, 'Jane', 18000),
    (3, 'Bob', 12000),
    (4, 'Alice', 10000),
    (5, 'Charlie', 8000);

-- Consulta para o valor total dos salários dos funcionários usando as funções sum e sumWithOverflow e exibe seus tipos usando a função toTypeName
-- Para a função sum, o tipo resultante é UInt64, grande o suficiente para conter a soma, enquanto para sumWithOverflow o tipo resultante permanece UInt16.

SELECT
    sum(monthly_salary) AS no_overflow,
    sumWithOverflow(monthly_salary) AS overflow,
    toTypeName(no_overflow),
    toTypeName(overflow)
FROM employees;
```

```response title=Response theme={null}
┌─no_overflow─┬─overflow─┬─toTypeName(no_overflow)─┬─toTypeName(overflow)─┐
│       68000 │     2464 │ UInt64                  │ UInt16               │
└─────────────┴──────────┴─────────────────────────┴──────────────────────┘
```
