hive行列转换总结

本文总结了Hive中如何进行行列转换,包括单列转多行、多行转单列以及多行转多列、多列转多行的操作。通过split和explode函数实现了单列到多行的转换,利用自定义UDF则可以完成多行到单列的转换。对于更复杂的多行转多列和多列转多行,可以参照相关博文进行操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、单列转换成多行

比如:

pageid  paged

page1   a,b,c

要转换成

page1 a

page1 b

page1 c

select pageid,p from test lateral view explode(split(paged,',')) adtable as p;


通过split拆成多个元素的集合,再通过explode打散成多行,lateral view作用是解决explode这种UDTF函数拆成的数据不能与其他字段共同服务问题

2、多行转换成单列

即上面的结果又反推回去,想到oracle的sys_connect_path,便写个UDF实现类似功能

import java.util.ArrayList;

import org.apache.hadoop.hive.ql.exec.UDF;
public class RowToCol extends UDF {
private static int MAX_VALUE = 50;

private static String prerows[] = new String[MAX_VALUE];//全局变量,保留上一条记录的值

private static StringBuilder val=null;

public String evaluate (Object ...args){
	
ArrayList<String> thisrowlist=new ArrayList<String>();
for(int i=0;i<args.length;i++)

	thisrowl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值