炸裂函数的用法
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