炸裂函数的用法
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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下