炸裂函数explode

Posted jbli

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了炸裂函数explode相关的知识,希望对你有一定的参考价值。

技术图片

 

lateral viem 表的关联只能和explode使用

hive> select explode(info) from t_map where id=1;

技术图片

技术图片

hive> create table watch(id int,name string) row format delimited fields terminated by " ";

 vim movie.txt

1 CN_lldd
2 CN_sjd
3 CN_jp
4 CN_rpt
5 USA_yns
6 USA_sd
7 USA_ydfdf
8 USA_gdffd



load data local inpath "/movie.txt" into table watch;

技术图片

//创建数据文件

1 lldq js|kh|dz|yq
2 sdyjq dz|js|js
3 yw ll|yq|dz

//上传数据

load data local inpath "/mv.txt" into table mv;

//将数据炸开

hive> select explode(split(types,"\\\\|")) from mv;

 

技术图片

//求有几种类型

hive> select count(*) from (select explode(split(types,"\\\\|"))type from mv) t group by t.type;

hive> select count(*),type from (select explode(split(types,"\\\\|"))type from mv) t group by t.type;

技术图片

//将炸裂的数据和 表关联 lateral view

hive> select id,name,type from mv lateral view explode(split(types,"\\\\|")) t as type 

技术图片

 

 

以上是关于炸裂函数explode的主要内容,如果未能解决你的问题,请参考以下文章

使用 Hive 炸裂函数 explode (map<string,string;) 宽表转高表

使用 Hive 炸裂函数 explode (map<string,string>) 宽表转高表

比较有用的php代码片段

php原生代码实现explode函数功能

Hive函数之explode和inline

Hive之explode()函数和posexplode()函数和lateral view函数