Hive炸裂函数explode的使用

21 篇文章 2 订阅

explode的作用

将一行集合类型的数据炸裂为多行数据。

格式

lateral view explode(字段) 表别名 as 列别名
如果字段类型是map:lateral view explode(字段) 表别名 as key别名,value别名

示例

有如下表数据

+-------------------+----------------------+
| movie_info.movie  | movie_info.category  |
+-------------------+----------------------+
| 《疑犯追踪》            | 悬疑,动作,科幻,剧情          |
| 《Lie to me》       | 悬疑,警匪,动作,心理,剧情       |
| 《战狼2| 战争,动作,灾难             |
+-------------------+----------------------+

想要的结果:

+--------------+-----------+
|   m.movie    | tbl.type  |
+--------------+-----------+
| 《疑犯追踪》       | 悬疑        |
| 《疑犯追踪》       | 动作        |
| 《疑犯追踪》       | 科幻        |
| 《疑犯追踪》       | 剧情        |
| 《Lie to me》  | 悬疑        |
| 《Lie to me》  | 警匪        |
| 《Lie to me》  | 动作        |
| 《Lie to me》  | 心理        |
| 《Lie to me》  | 剧情        |
| 《战狼2| 战争        |
| 《战狼2| 动作        |
| 《战狼2| 灾难        |
+--------------+-----------+
select movie,tbl.type
from movie_info
lateral view explode(split(category,',')) tbl as type;

如果想要如下结果:

+-----------+-----------------------------------+
| tbl.type  |                _c1                |
+-----------+-----------------------------------+
| 剧情        | ["《疑犯追踪》","《Lie to me》"]          |
| 动作        | ["《疑犯追踪》","《Lie to me》","《战狼2》"]  |
| 心理        | ["《Lie to me》"]                   |
| 悬疑        | ["《疑犯追踪》","《Lie to me》"]          |
| 战争        | ["《战狼2》"]                         |
| 灾难        | ["《战狼2》"]                         |
| 科幻        | ["《疑犯追踪》"]                        |
| 警匪        | ["《Lie to me》"]                   |
+-----------+-----------------------------------+

这个是列转行的实现,我们可以按照类型分组,然后把电影名放在集合中。

select tbl.type,collect_list(movie)
from movie_info
lateral view explode(split(category,',')) tbl as type
group by tbl.type;
  • 13
    点赞
  • 56
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值