炸裂函数的用法

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 2022-06-21 21:36  大鹏的鸿鹄之志  阅读(286)  评论(0编辑  收藏  举报