自定义UDF
package hive.udf;import org.apache.hadoop.hive.ql.exec.Description;import org.apache.hadoop.hive.ql.exec.UDF;/*** UDF的说明文档* name是UDF的名称* value是desc function xx输出的内容* extended是desc function extended xx输出的内容**/@Description(name="uppernum",value="_FUNC_ the input is a num, the output is the UpperNum",extended="Example:\n" +"> select uppernum(1) from src \n")public class UpperNumUDF extends UDF {/*** UDF类需要自定义evaluate方法,可以重载多个** evaluate的参数、返回值必须是hive可以序列化的类型** 参数:* 1)可以是java基本类型、String* 2)可以是Text* 3)可以包含多个参数,参数类型也可以不同* 4)可以是List<?>。如果hive表字段是Array<?>类型的,则是List** 返回值:* 1)必须有返回值,可以为null* 2)返回值只能是java基本类型、String、Writable** 可以自定义 UDFMethodResolver来手动匹配方法的执行** @param num* @return*/public String evaluate(int num) {String str = "ERROR";switch (num) {case 0:str = "零";break;case 1:str = "壹";break;case 2:str = "贰";break;case 3:str = "叁";break;case 4:str = "肆";break;case 5:str = "伍";break;default:break;}return str;}public String evaluate(String num) {int intnum = 100;try {intnum = Integer.parseInt(num);} catch (NumberFormatException e) {}return evaluate(intnum);}}
hive (test)> add jar ${env:HOME}/udf.jar;
hive (test)> create [temporary] function uppernum as 'hive.udf.UpperNumUDF';
hive (test)> select uppernum(2) from dual;OK贰Time taken: 0.118 seconds, Fetched: 1 row(s)hive (test)> select uppernum(5) from dual;OK伍
hive (test)> desc function uppernum;OKuppernum the input is a num, the output is the UpperNumTime taken: 0.138 seconds, Fetched: 1 row(s)hive (test)> desc function extended uppernum;OKuppernum the input is a num, the output is the UpperNumExample:> select uppernum(1) from srcTime taken: 0.138 seconds, Fetched: 4 row(s)
hive> drop [temporary] function uppernum;OKTime taken: 0.221 seconds
附件列表
自定义UDF的更多相关文章
- Hive UDF IP解析(二):使用geoip2数据库自定义UDF
开发中经常会碰到将IP转为地域的问题,所以以下记录Hive中自定义UDF来解析IP. 使用到的地域库位maxmind公司的geoIP2数据库,分为免费版GeoLite2-City.mmdb和收费版Ge ...
- 自定义udf添加一列
//创建得分窗口字典 var dict= new mutable.HashMap[Double, Int]() ){ dict.put(result_Score(i),i) } //自定义Udf函数 ...
- 2.13 Hive中自带Function使用及自定义UDF编程
UDF:User Definition Function 一.function #查看自带的函数 hive (db_hive)> show functions; #查看一个函数的详细用法 hiv ...
- 自定义UDF函数应用异常
自定义UDF函数应用异常 版权声明:本文为yunshuxueyuan原创文章.如需转载请标明出处: http://www.cnblogs.com/sxt-zkys/QQ技术交流群:299142667 ...
- 如何给Apache Pig自定义UDF函数?
近日由于工作所需,需要使用到Pig来分析线上的搜索日志数据,散仙本打算使用hive来分析的,但由于种种原因,没有用成,而Pig(pig0.12-cdh)散仙一直没有接触过,所以只能临阵磨枪了,花了两天 ...
- Hive 自定义UDF操作步骤
Hive 自定义UDF操作步骤 需要自定义类,然后继承UDF 然后在方法envluate()方法里面实现具体的业务逻辑,打包上传到linux(以免出错打包成RunningJar) 一.创建临时函数 ( ...
- 【Spark篇】---SparkSQL中自定义UDF和UDAF,开窗函数的应用
一.前述 SparkSQL中的UDF相当于是1进1出,UDAF相当于是多进一出,类似于聚合函数. 开窗函数一般分组取topn时常用. 二.UDF和UDAF函数 1.UDF函数 java代码: Spar ...
- 047 SparkSQL自定义UDF函数
一:程序部分 1.需求 Double数据类型格式化,可以给定小数点位数 2.程序 package com.scala.it import org.apache.spark.{SparkConf, Sp ...
- Spark(十三)【SparkSQL自定义UDF/UDAF函数】
目录 一.UDF(一进一出) 二.UDAF(多近一出) spark2.X 实现方式 案例 ①继承UserDefinedAggregateFunction,实现其中的方法 ②创建函数对象,注册函数,在s ...
随机推荐
- Python中Gradient Boosting Machine(GBM)调参方法详解
原文地址:Complete Guide to Parameter Tuning in Gradient Boosting (GBM) in Python by Aarshay Jain 原文翻译与校对 ...
- (转)Python3之requests模块
原文:https://www.cnblogs.com/wang-yc/p/5623711.html Python标准库中提供了:urllib等模块以供Http请求,但是,它的 API 太渣了.它是为另 ...
- CentOS7下RabbitMQ服务安装配置
参考文档: CentOS7下RabbitMQ服务安装配置 http://www.linuxidc.com/Linux/2016-03/129557.htm 在linux下安装配置rabbitMQ详细教 ...
- Android使用bindService作为中间人对象开启服务
Android使用bindService作为中间人对象开启服务 项目结构如下: MyService: package com.demo.secondservice; import android.ap ...
- 微信 OAuth2 网页授权获取用户信息
文档:http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html !!! 微信跟用户没有关系类接口采用了OAUTH2 [ ...
- Memcache for Windows
要求 必备知识 熟悉基本编程环境搭建. 运行环境 windows 7(64位); memcached-1.2.6 下载地址 环境下载 什么是MemCache memcache是一套分布式的高速缓存系统 ...
- 05 - JavaSE之数组
一维数组 java中的数组是引用类型,分配在堆空间上. 一维数组的声明方式: type var[]; type[] var; java中声明数组时不能指定其长度,如下,因为java中的数组是分配在堆空 ...
- php 通过 strtr 方法来替换文本中指定的内容
通过在文本中指定待替换的内容,如: [{name}] [{age}] 格式可以自己定义, 大概过程: 在文本中定义需要替换的文本内容: 以键值对的方式 组织数据(数组): 用 file_get_con ...
- gateway-workman
最外层start.php,设置全局启动模式,加载Application里的个子服务目录下应用的启动文件(start开头,这些文件都是workman\work类的子类,在载入文件的同时,这些子服务会生成 ...
- CentOS Basic XLib functionality test failed!
在CentOS上安装个Qt库时,下好源代码之后执行: ./configure检查环境时,出现: Basic XLib functionality test failed! You might need ...