hive自定义函数

函数相关语法

简介:

hive自定义函数根据作用范围分为:临时函数、永久自定义函数。临时函数仅对当前回话有效。而临时函数函数可以注册到元存储,因此可以在查询中引用它们,而不必在每个会话中创建临时函数。

自定义函数语法

  • 创建临时函数:CREATE TEMPORARY FUNCTION function_name AS class_name;
  • 删除临时函数:DROP TEMPORARY FUNCTION [IF EXISTS] function_name;
  • 创建永久自定义函数: CREATE FUNCTION [db_name.]function_name AS class_name [USING JAR|FILE|ARCHIVE 'file_uri' [, JAR|FILE|ARCHIVE 'file_uri'] ];
  • 删除永久自定义函数: DROP FUNCTION [IF EXISTS] function_name;
  • 重载自定义函数:RELOAD (FUNCTIONS|FUNCTION);

相关函数相关实例

新建普通Java项目,引入相关依赖:

 <dependency>
    <groupId>org.apache.hive</groupId>
    <artifactId>hive-exec</artifactId>
    <version>${hive.version}</version>
</dependency>

 <dependency>
    <groupId>org.apache.hive</groupId>
    <artifactId>hive-common</artifactId>
    <version>${hive.version}</version>
  </dependency>

新建一个类继承org.apache.hadoop.hive.ql.exec.UDF并重写evaluate方法,如:

public class HiveFunction extends UDF {

    public String evaluate(String src) {
        return src.toLowerCase();
    }


    public Integer evaluate(String src,String str1) {
        return src.length() + str1.length();
    }

}

将该项目打包: mvn clean install -Dmaven.skip.test=true -U -X

临时函数注册:
添加的jar是本地路径,而非hdfs路径,如:

 add jar /IdeaProjects/hive-demo/target/hive-demo-1.0-SNAPSHOT.jar;

创建名为hivefunction的临时函数:create temporary function hivefunction as 'cn.nankong.function.HiveFunction';

简单实用示例:
在这里插入图片描述
删除临时自定义函数: DROP TEMPORARY FUNCTION hivefunction; 删除后再次使用报错:
在这里插入图片描述
创建永久函数:
将自定义开发函数jar上传到hdfs,如:hdfs dfs -put /Users/luchengwen/IdeaProjects/hive-demo/target/hive-demo-1.0-SNAPSHOT.jar /hiveJar

创建永久自定义函数:

create function default.hivefunction as 'cn.nankong.function.HiveFunction' using jar 'hdfs://127.0.0.1:9000/hiveJar/hive-demo-1.0-SNAPSHOT.jar'

执行后永久自定函数信息已保存到元数据中:
在这里插入图片描述
删除永久自定义函数:

DROP FUNCTION hivefunction;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值