博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
计算平均数UDAF
阅读量:5221 次
发布时间:2019-06-14

本文共 1707 字,大约阅读时间需要 5 分钟。

package com.suning.udf;import org.apache.hadoop.hive.ql.exec.UDAF;import org.apache.hadoop.hive.ql.exec.UDAFEvaluator;public class Avg extends UDAF {    public static class AvgState {        private long mCount;        private double mSum;    }    public static class AvgEvaluator implements UDAFEvaluator {        AvgState state;        public AvgEvaluator() {            super();            state = new AvgState();            init();        }        /**         * init函数类似于构造函数,用于UDAF的初始化         */        public void init() {            state.mSum = 0;            state.mCount = 0;        }        /**         * iterate接收传入的参数,并进行内部的轮转。其返回类型为boolean * * @param o * @return         */        public boolean iterate(Double o) {            if (o != null) {                state.mSum += o;                state.mCount++;            }            return true;        }        /**         * terminatePartial无参数,其为iterate函数遍历结束后,返回轮转数据, * terminatePartial类似于hadoop的Combiner * * @return         */        public AvgState terminatePartial() {            // combiner            return state.mCount == 0 ? null : state;        }        /**         * merge接收terminatePartial的返回结果,进行数据merge操作,其返回类型为boolean * * @param o * @return         */        public boolean merge(AvgState avgState) {            if (avgState != null) {                state.mCount += avgState.mCount;                state.mSum += avgState.mSum;            }            return true;        }        /**         * terminate返回最终的聚集函数结果 * * @return         */        public Double terminate() {            return state.mCount == 0 ? null : Double.valueOf(state.mSum / state.mCount);        }    }}

 

转载于:https://www.cnblogs.com/yin-fei/p/10879719.html

你可能感兴趣的文章
201771010125王瑜《面向对象程序设计(Java)》第十三周学习总结
查看>>
手机验证码执行流程
查看>>
python 基础 ----- 变量
查看>>
设计模式课程 设计模式精讲 2-2 UML类图讲解
查看>>
Silverlight 的菜单控件。(不是 Toolkit的)
查看>>
:hover 鼠标同时触发两个元素变化
查看>>
go语言学习十三 - 相等性
查看>>
Idea 提交代码到码云(提交到github也大同小异)
查看>>
c#连接excel2007未安装ISAM解决
查看>>
Mono 异步加载数据更新主线程
查看>>
初识lua
查看>>
我是插件狂人,jDuang,jValidator,jModal,jGallery
查看>>
张季跃 201771010139《面向对象程序设计(java)》第四周学习总结
查看>>
如何解除循环引用
查看>>
android中fragment的使用及与activity之间的通信
查看>>
字典【Tire 模板】
查看>>
jquery的contains方法
查看>>
python3--算法基础:二分查找/折半查找
查看>>
Perl IO:随机读写文件
查看>>
Perl IO:IO重定向
查看>>