ClickHouse/docs/en/sql-reference/aggregate-functions/reference/topk.md

2.0 KiB
Raw Blame History

slug sidebar_position
/en/sql-reference/aggregate-functions/reference/topk 202

topK

Returns an array of the approximately most frequent values in the specified column. The resulting array is sorted in descending order of approximate frequency of values (not by the values themselves).

Implements the Filtered Space-Saving algorithm for analyzing TopK, based on the reduce-and-combine algorithm from Parallel Space Saving.

topK(N)(column)
topK(N, load_factor)(column)
topK(N, load_factor, 'counts')(column)

This function does not provide a guaranteed result. In certain situations, errors might occur and it might return frequent values that arent the most frequent values.

We recommend using the N < 10 value; performance is reduced with large N values. Maximum value of N = 65536.

Parameters

  • N — The number of elements to return. Optional. Default value: 10.
  • load_factor — Defines, how many cells reserved for values. If uniq(column) > N * load_factor, result of topK function will be approximate. Optional. Default value: 3.
  • counts — Defines, should result contain approximate count and error value.

Arguments

  • column — The value to calculate frequency.

Example

Take the OnTime data set and select the three most frequently occurring values in the AirlineID column.

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

See Also