玖叶教程网

前端编程开发入门

SQL| 如何在Hive中实现group_concat功能?


今天要讲取如何在hive中实现group_concat的实现方法,喜欢的友友记得点赞?关注,我们一起学习一起进步哦[来看我]。


大家都知道,mysql中的group_concat分组连接功能相当强大,可以先分组再连接成字符串,还可以进行排序连接。但是hive中并没有这个函数,那么hive中怎么实现这个功能呢?


这里要用到:concat_ws函数和collect_list、collect_set 函数来实现相同的功能。


1. 建立测试表(无分区表):

2.实现?方法?一?: concat_ws + collect_set + group by

1)SQL代码

select
id,
concat_ws(',',collect_set(content)) as con_con,
concat_ws(',',collect_set(comment)) as con_com
  from db_name.test_tb
group by id

2)结果解读?:无序且不对应(con_con与con_com的位置)


—— 但是注意 collect_set会将重复的数据删除,因为集合的性质。

每次运行连接的结果顺序都可能不一样。


3. 实现?方法二?:concat_ws + collect_list + group by

1)SQL代码

select
id,
concat_ws(',',collect_list(content)) as con_con,
concat_ws(',',collect_list(comment)) as con_com
from db_name.test_tb
group by id

2)结果解读?:对应(con_con与con_com的位置)但无序。



发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言