Hive UDF开发

本文介绍了如何使用Hive进行UDF开发,特别关注了Temporary function的实现步骤,并通过实例展示了从Java文件到UDF创建的全过程。包括编译、添加jar、创建临时函数及使用过程,同时指出了临时函数的局限性和UDF的一进一出特性。

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

 Hive进行UDF开发十分简单,此处所说UDF为Temporary的function,所以需要hive版本在0.4.0以上才可以。


Hive的UDF开发只需要重构UDF类的evaluate函数即可。例:


package com.hrj.hive.udf;


import org.apache.hadoop.hive.ql.exec.UDF;


public class helloUDF extends UDF {


    public String evaluate(String str) {


        try {


            return "HelloWorld " + str;


        } catch (Exception e) {


            return null;


        }


    }





 


将该java文件编译成helloudf.jar


hive> add jar helloudf.jar;


hive> create temporary function helloworld as 'com.hrj.hive.udf.helloUDF';


hive> select helloworld(t.col1) from t limit 10;


hive> drop temporary function helloworld;


 


注:


1.helloworld为临时的函数,所以每次进入hive都需要add jar以及create temporary操作


2.UDF只能实现一进一出的操作,如果需要实现多进一出,则需要实现UDAF

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值