gpt4 book ai didi

java - Hive 中的 COLLECT_SET(),保留重复项?

转载 作者:IT老高 更新时间:2023-10-28 20:51:11 25 4
gpt4 key购买 nike

有没有办法将重复项保存在 Hive 的收集集中,或者使用其他方法模拟 Hive 提供的那种聚合集合?我想将列中具有相同键的所有项目聚合到一个数组中,并带有重复项。

IE:

hash_id | num_of_cats
=====================
ad3jkfk 4
ad3jkfk 4
ad3jkfk 2
fkjh43f 1
fkjh43f 8
fkjh43f 8
rjkhd93 7
rjkhd93 4
rjkhd93 7

应该返回:

hash_agg | cats_aggregate
===========================
ad3jkfk Array<int>(4,4,2)
fkjh43f Array<int>(1,8,8)
rjkhd93 Array<int>(7,4,7)

最佳答案

在 Hive 0.13.0 之后尝试使用 COLLECT_LIST(col)

SELECT
hash_id, COLLECT_LIST(num_of_cats) AS aggr_set
FROM
tablename
WHERE
blablabla
GROUP BY
hash_id
;

关于java - Hive 中的 COLLECT_SET(),保留重复项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6445339/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com