阿里云Lateral View 行转列

阿里云Lateral View 行转列

示例数据

假设已有一张表pageAds,它有三列数据,第一列是pageid string,第二列是col1 array,第三列是col2 array,详细数据如下。
pageid col1 col2
front_page [1, 2, 3] [“a”, “b”, “c”]
contact_page [3, 4, 5] [“d”, “e”, “f”]

使用示例

单个Lateral View语句
示例1:拆分col1。命令示例如下:
select pageid, col1_new, col2 from pageAds lateral view explode(col1) adTable as col1_new;

返回结果如下:
±-----------±-----------±-----------+
| pageid | col1_new | col2 |
±-----------±-----------±-----------+
| front_page | 1 | [“a”,“b”,“c”] |
| front_page | 2 | [“a”,“b”,“c”] |
| front_page | 3 | [“a”,“b”,“c”] |
| contact_page | 3 | [“d”,“e”,“f”] |
| contact_page | 4 | [“d”,“e”,“f”] |
| contact_page | 5 | [“d”,“e”,“f”] |
±-----------±-----------±-----------+

示例2:拆分col1并执行聚合统计。命令示例如下:
select col1_new, count(1) as count from pageAds lateral view explode(col1) adTable as col1_new group by col1_new;

返回结果如下:
±-----------±-----------+
| col1_new | count |
±-----------±-----------+
| 1 | 1 |
| 2 | 1 |
| 3 | 2 |
| 4 | 1 |
| 5 | 1 |
±-----------±-----------+

多个Lateral View语句
拆分col1和col2。命令示例如下:
select pageid,mycol1, mycol2 from pageAds
lateral view explode(col1) myTable1 as mycol1
lateral view explode(col2) myTable2 as mycol2;

返回结果如下:
±-----------±-----------±-----------+
| pageid | mycol1 | mycol2 |
±-----------±-----------±-----------+
| front_page | 1 | a |
| front_page | 1 | b |
| front_page | 1 | c |
| front_page | 2 | a |
| front_page | 2 | b |
| front_page | 2 | c |
| front_page | 3 | a |
| front_page | 3 | b |
| front_page | 3 | c |
| contact_page | 3 | d |
| contact_page | 3 | e |
| contact_page | 3 | f |
| contact_page | 4 | d |
| contact_page | 4 | e |
| contact_page | 4 | f |
| contact_page | 5 | d |
| contact_page | 5 | e |
| contact_page | 5 | f |
±-----------±-----------±-----------+

简单来说 记住使用 lateral view explode

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值