随笔 - 126  文章 - 0  评论 - 5  阅读 - 94915

炸裂函数的用法

hive explode函数可以将一个array或者map展开,其中explode(array)使得结果中将array列表里的每个元素生成一行;explode(map)使得结果中将map里的每一对元素作为一行,key为一列,value为一列,一般情况下,直接使用即可,但是遇到以下情况时需要结合lateral view 使用。

 

复制代码
 1 SELECT
 2 *
 3 ,SPLIT(myCol1,',')[2] AS bucket_id
 4 ,SPLIT(myCol1,',')[0] AS exp_layer_id
 5 ,SPLIT(myCol1,',')[1] AS exp_id
 6 FROM
 7 (
 8 SELECT 
 9 '1,2,4|3,5,6' as scene_exp_str
10 ) t1 
11 lateral view explode(SPLIT(scene_exp_str,'\\|')) col1Table AS myCol1     ---- SPLIT(scene_exp_str,'\\|') 出来是个数组 , lateral view explode(SPLIT(scene_exp_str,'\\|')) 出来的 myColl 是一个string 
复制代码

 

 

 

转载:https://www.jianshu.com/p/0a773273ff4a

posted on   大鹏的鸿鹄之志  阅读(351)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示