HIVE 一行转多行输出办法
生活随笔
收集整理的這篇文章主要介紹了
HIVE 一行转多行输出办法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
2019獨角獸企業重金招聘Python工程師標準>>>
1.問題描述
hive UDF?格式:oc號1_an號1_次數;oc號2_an號2_次數
轉換結果: oc號1 an號1 次數
? ? ? ? ? ? ? ? ? oc號2 an號2 次數
一行轉多行,一行轉多列
2.實現思路
第一步分割:split('oc號1_an號1_次數;oc號2_an號2_次數',';') 結果Array<String> oc_an = [oc號1_an號1_次數,oc號2_an號2_次數]第二步拆分:explode(oc_an) ?(參考文檔:A) 結果:
第三分割:split('oc號1_an號1_次數,'_')
第四步: 一行轉多列? 簡單用split分割,不過也可以寫UDTF行數轉換
3.實現案例
select ip, split(OC_AN ,'_')[0] as oc,split(OC_AN ,'_')[1] as an,split(OC_AN ,'_')[2] as click from longyuan_pps_base_hour LATERAL VIEW explode(split('100_101_3\;101_102_5','\;')) adTable AS OC_AN?where ?pf=201 ?and p=11 and p1=114 and t=11? and bs='action__logo_view_auto' and dt='20140213'4.參考文檔
A.https://cwiki.apache.org/confluence/display/Hive/LanguageManual+LateralView B.http://dacoolbaby.iteye.com/blog/1932077 福音轉載于:https://my.oschina.net/guoenzhou/blog/389685
總結
以上是生活随笔為你收集整理的HIVE 一行转多行输出办法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 女性梦到割韭菜什么寓意
- 下一篇: 梦到以前的恋人是什么意思