uniqHLL12
使用 HyperLogLog 算法计算不同参数值的近似数量。
参数
该函数接受一个可变数量的参数。参数可以是 Tuple
、Array
、Date
、DateTime
、String
或数值类型。
返回值
- 一个 UInt64 类型的数字。
实现细节
函数:
-
对聚合中的所有参数计算哈希值,然后在计算中使用它。
-
使用 HyperLogLog 算法来近似估算不同参数值的数量。
使用 2^12 个 5 位单元格。状态大小稍超过 2.5 KB。对于小数据集 (<10K 元素),结果的准确性不是很好(误差可达 ~10%)。然而,对于高基数数据集(10K-100M),结果相当准确,最大误差约为 ~1.6%。从 100M 开始,估计误差增加,对于具有极高基数的数据集(1B+ 元素),函数将返回非常不准确的结果。
-
提供确定的结果(不依赖于查询处理顺序)。
我们不推荐使用此函数。在大多数情况下,使用 uniq 或 uniqCombined 函数。
参见