自定义函数

  1. 根据用户自定义函数类别分为以下三种:
  1. UDF(user-defined function):一进一出
  2. UDAF:聚集函数,多进一出(类似于:count/max/min)
  3. UDTF:一进多出   eg.lateral view explode()
  1. 编程步骤:(1)继承Hive提供的类:

org.apache.hadoop.hive.ql.udf.generic.GenericUDF

org.apache.hadoop.hive.ql.udf.generic.GenericUDTF;

(2)实现类中的抽象方法

(3)在Hive的命令行窗口创建函数:①添加jar:

add jar linux_jar_path

②创建function:

create [temporary] function [dbname.] function_name AS calss_name;

  1. 在Hive的命令行窗口删除函数

drop [temporary] function [if exists] [dename.] function_name;

  1. 自定义UDF函数:(1)需求:自定义一个UDF实现计算给定字符串的长度

eg.hive(default) > select my_len(“abcd”)

4

(2)创建一个Maven工程Hive

  1. 导入依赖:

(4)创建一个类:

package com.zhengkw.userfunction;

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

/**

 * @ClassName:UserUDF

 * @author: zhengkw

 * @description: 自定义 udf

 * @date: 20/03/11上午 12:26

 * @version:1.0

 * @since: jdk 1.8

 */

public class UserUDF extends UDF {

    /**

     * @param s

     * @descrption: 方法名只能是evaluate!!!!!

     * @return: 返回类型不能为void,可以为 null

     * @date: 20/03/11 上午 1:06

     * @author: zhengkw

     */

    public String evaluate(final String s) {

        if (s == null) {

            return null;

        }

         //返回一个小写字符串

        return s.toLowerCase();

    }

}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZSup{A}

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值