栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

Hive 利用lateral view, explode, split函数实现行转列

Hive 利用lateral view, explode, split函数实现行转列

问题:
一个联系人可能有多个号码,但是源表存的时候是放在一个字段的,分隔的形式也是多种多样,现在需要将它们一个个分开,实现行转列。

举个例子,源表(phone_info)为

namelinkman_phone
小明126;946:789*235

实现的结果为

namephone_number
小明126
小明946
小明789
小明235

有兴趣的朋友可以先试试,不急着往后看解析。

解析思路:

利用split函数将合并在一起的字段拆分开,然后利用lateral view和explode函数将其展开显示。

代码如下:

select name,phone_number 
from phone_info
lateral view explode(split(linkman_phone,'[\;|\:|\*|\|]')) mytable as phone_number;

给大家排坑:
我自己最开始在写的时候犯了个错误,很简单的错误,就是忘了select新生成的列啊,然后一直以为没有实现行转列。

比如,下面这样写是不行的。

错误代码!

select name,linkman_phone
from phone_info
lateral view explode(split(linkman_phone,'[\;|\:|\*|\|]')) mytable as phone_number;

有任何问题也欢迎留言交流,互相学习,共同进步。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/677115.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号