hive sql 多行转为一行&&collect_set&&collect_list的区别

本文介绍了Hive SQL中的collect_list和collect_set函数,用于将多行数据转换为一行。collect_list保留顺序但可能包含重复值,而collect_set则会去除重复值但顺序不保证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.collect_list 多行转一行,有序不去重

数据

select 123 uid,'a' name, int(1) type
from t
union all
select 123 uid,'b' name, int(2) type
from t
union all
select 123 uid,'c' name, int(3) type
from t
union all
select 123 uid,'d' name, int(4) type
from t
union all
select 122 uid,'a' name, int(1) type
from t
union all
select 122 uid,'b' name, int(2) type
from t
union all
select 122 uid,'c' name, int(3) type
from t
union all
select 124 uid,'a' name, int(1) type
from t
union all
select 124 uid,'b' name, int(3) type
from t

TEMP t= select uid,name from temp_2019123102 distribute by uid sort by type 
OUTPUT sel
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值