メインコンテンツへスキップ
メインコンテンツへスキップ

topKWeighted

指定されたカラム内で、おおよそ頻度が最も高い値の配列を返します。結果の配列は、値そのものではなく値のおおよその出現頻度に基づいて降順にソートされます。さらに、値の重みも考慮されます。

構文

topKWeighted(N)(column, weight)
topKWeighted(N, load_factor)(column, weight)
topKWeighted(N, load_factor, 'counts')(column, weight)

パラメーター

  • N — 返される要素数。省略可能です。デフォルト値: 10。
  • load_factor — 値用に予約されるセル数を定義します。もし uniq(column) > N * load_factor の場合、topK 関数の結果は近似値になります。省略可能です。デフォルト値: 3。
  • counts — 結果に近似カウントと誤差を含めるかどうかを指定します。

引数

  • column — 値。
  • weight — 重み。各値は頻度計算において weight 回分として考慮されます。 UInt64

戻り値

重みの近似和が最大となる値の配列を返します。

クエリ:

SELECT topKWeighted(2)(k, w) FROM
VALUES('k Char, w UInt64', ('y', 1), ('y', 1), ('x', 5), ('y', 1), ('z', 10))

結果:

┌─topKWeighted(2)(k, w)──┐
│ ['z','x']              │
└────────────────────────┘

クエリ:

SELECT topKWeighted(2, 10, 'counts')(k, w)
FROM VALUES('k Char, w UInt64', ('y', 1), ('y', 1), ('x', 5), ('y', 1), ('z', 10))

結果:

┌─topKWeighted(2, 10, 'counts')(k, w)─┐
│ [('z',10,0),('x',5,0)]              │
└─────────────────────────────────────┘

関連項目