hive行列转换

来源:互联网 发布:摄影测量数据处理软件 编辑:程序博客网 时间:2024/05/01 03:20

1.行专列

表数据:

name ,subject ,score

xiaoming|english|92.0
xiaoming|chinese|98.0
xiaoming|math|89.5
huahua|chinese|80.0
huahua|math|89.5

hive (hive)> select name,concat_ws(',',collect_set(concat(subject,'=',score))) from student group by name;
huahua chinese=80,math=89.5
xiaoming english=92,chinese=98,math=89.5


2、列转行

表数据

name ,subject_score_list

huahua|chinese=80,math=89.5
xiaoming|english=92,chinese=98,math=89.5

hive (hive)> select name, subject_list from student2 stu2 lateral view explode(split(stu2.subject_score_list,','))stu_subj as subject_list;

huahua chinese=80
huahua math=89.5
xiaoming english=92
xiaoming chinese=98
xiaoming math=89.5

0 0
原创粉丝点击