ClickHouse/docs/zh/sql-reference/aggregate-functions/reference/topk.md
2021-03-25 17:09:19 +08:00

1.2 KiB
Raw Blame History

toc_priority
108

topK

返回指定列中近似最常见值的数组。 生成的数组按值的近似频率降序排序(而不是值本身)。

实现了过滤节省空间算法, 使用基于reduce-and-combine的算法借鉴并行节省空间

语法

topK(N)(column)

此函数不提供保证的结果。 在某些情况下,可能会发生错误,并且可能会返回不是最高频的值。

我们建议使用 N < 10 值,N 值越大,性能越低。最大值 N = 65536

参数

  • N 是要返回的元素数。

如果省略该参数则使用默认值10。

参数

  • x 计算的频率值。

示例

就拿 OnTime 数据集来说,选择AirlineID 列中出现最频繁的三个。

SELECT topK(3)(AirlineID) AS res
FROM ontime
┌─res─────────────────┐
│ [19393,19790,19805] │
└─────────────────────┘