hive udaf_hive自定义udaf函数

本文介绍了如何在Hive中创建一个名为SumRes的自定义UDAF(用户定义聚合函数),用于对整数类型的数值进行求和操作。通过覆盖`GenericUDAFEvaluator`的方法,实现了在Map、Combiner和Reduce阶段的数据处理,包括初始化、迭代、合并和终止等功能。
摘要由CSDN通过智能技术生成

public class Sum extendsAbstractGenericUDAFResolver {//创建log对象,用于抛出错误和异常

static final Log log = LogFactory.getLog(Sum.class.getName());//判断sql语句传入的参数的个数和类型,并将其返回相应的类型

@Overridepublic GenericUDAFEvaluator getEvaluator(TypeInfo[] info) throwsSemanticException {//判断参数的个数是否符合要求

if (info.length != 1) {throw new UDFArgumentTypeException(info.length - 1, "exactly one parameter expected");

}//判断传入的参数类型

if (info[0].getCategory() !=ObjectInspector.Category.PRIMITIVE) {throw new UDFArgumentTypeException(0, "only primitive argument is expected but " +info[0].getTypeName() + "is passed");

}//对传入的参数类型进行进一步的判断是否是我们需求的数据的类型

switch (((PrimitiveTypeInfo) info[0]).getPrimitiveCategory()) {caseBYTE:caseSHORT:caseINT:caseLONG:caseFLOAT:caseDOUBLE:return newSumRes();default:throw new UDFArgumentTypeException(0, "only numric type is expected but " + inf

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值