> ## 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.

> 서로 다른 인수 값의 대략적인 개수를 계산합니다.

# uniqCombined

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

도입 버전: v1.1.0

서로 다른 인수 값의 대략적인 개수를 계산합니다.
결과는 결정론적으로 반환됩니다(쿼리 처리 순서에 의존하지 않음).

<Note>
  String이 아닌 타입에는 32비트 해시를 사용하므로, 카디널리티가 `UINT_MAX`보다 훨씬 크면 결과 오차가 매우 커집니다(고유 값이 수백억 개를 넘기 시작하면 오차가 빠르게 증가합니다).
  카디널리티가 `UINT_MAX`보다 큰 경우에는 대신 [`uniqCombined64`](/ko/reference/functions/aggregate-functions/uniqCombined64)를 사용하세요.
</Note>

`uniq` 함수와 비교하면 `uniqCombined` 함수는 다음과 같은 특징이 있습니다.

* 메모리 사용량이 몇 배 더 적습니다
* 정확도가 몇 배 더 높습니다
* 일반적으로 성능은 약간 더 낮습니다. 다만 일부 시나리오에서는 `uniqCombined`가 `uniq`보다 더 나은 성능을 낼 수 있습니다. 예를 들어, 네트워크를 통해 많은 수의 집계 상태를 전송하는 분산 쿼리에서 그렇습니다

<Accordion title="구현 세부 사항">
  이 함수는 집계의 모든 매개변수에 대해 해시(String에는 64비트 해시, 그 외에는 32비트)를 계산한 다음, 이를 계산에 사용합니다.
  이 함수는 배열, 해시 테이블, 그리고 오차 보정 테이블이 포함된 HyperLogLog를 조합한 세 가지 알고리즘을 사용합니다:

  * 고유 원소 수가 적을 때는 배열을 사용합니다
  * 집합 크기가 더 커지면 해시 테이블을 사용합니다
  * 원소 수가 더 많아지면 HyperLogLog를 사용하며, 이 경우 고정된 양의 메모리를 사용합니다
</Accordion>

**구문**

```sql theme={null}
uniqCombined(HLL_precision)(x[, ...])
uniqCombined(x[, ...])
```

**매개변수**

* `HLL_precision` — 선택 사항입니다. HyperLogLog의 셀 수에 대한 밑이 2인 로그입니다. 기본값은 17이며, 이는 실질적으로 96 KiB의 공간(2^17개 셀, 각 6비트)에 해당합니다. 범위: \[12, 20]. [`UInt8`](/ko/reference/data-types/int-uint)

**인수**

* `x` — 개수가 가변적인 인수입니다. [`Tuple(T)`](/ko/reference/data-types/tuple) 또는 [`Array(T)`](/ko/reference/data-types/array) 또는 [`Date`](/ko/reference/data-types/date) 또는 [`DateTime`](/ko/reference/data-types/datetime) 또는 [`String`](/ko/reference/data-types/string) 또는 [`(U)Int*`](/ko/reference/data-types/int-uint) 또는 [`Float*`](/ko/reference/data-types/float) 또는 [`Decimal`](/ko/reference/data-types/decimal)

**반환 값**

서로 다른 인수 값의 대략적인 개수를 나타내는 UInt64 타입의 숫자를 반환합니다. [`UInt64`](/ko/reference/data-types/int-uint)

**예시**

**기본 사용법**

```sql title=Query theme={null}
SELECT uniqCombined(number) FROM numbers(1e6);
```

```response title=Response theme={null}
┌─uniqCombined(number)─┐
│              1001148 │
└──────────────────────┘
```

**사용자 지정 정밀도**

```sql title=Query theme={null}
SELECT uniqCombined(15)(number) FROM numbers(1e5);
```

```response title=Response theme={null}
┌─uniqCombined(15)(number)─┐
│                   100768 │
└──────────────────────────┘
```

**관련 항목**

* [uniq](/ko/reference/functions/aggregate-functions/uniq)
* [uniqCombined64](/ko/reference/functions/aggregate-functions/uniqCombined64)
* [uniqHLL12](/ko/reference/functions/aggregate-functions/uniqHLL12)
* [uniqExact](/ko/reference/functions/aggregate-functions/uniqExact)
* [uniqTheta](/ko/reference/functions/aggregate-functions/uniqthetasketch)
