UDF

package fang.qiang;

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 'fang.qiang.helloUDF';
hive> select helloworld(t.col1) from t limit 10;
hive> drop temporary function helloworld;

UDAF

import org.apache.hadoop.hive.ql.exec.Description;
import org.apache.hadoop.hive.ql.exec.UDAF;
import org.apache.hadoop.hive.ql.exec.UDAFEvaluator;

/**
 * 计算平均值
 */
public final class UDAFExampleAvg extends UDAF {

    /**
     * 定义一个类保存中间过程结果
     */
    public static class UDAFAvgState {
        private long mCount;
        private double mSum;
    }

    /**
     * 这是真正的实现聚合的类,hive自动从UDAF类中寻找继承了UDAFEvaluator的内部类
     */
    public static class UDAFExampleAvgEvaluator implements UDAFEvaluator {

        UDAFAvgState state;

        public UDAFExampleAvgEvaluator() {
            super();
            state = new UDAFAvgState();
            init();
        }

        /**
         * Reset the state of the aggregation.
         */
        public void init() {
            state.mSum = 0;
            state.mCount = 0;
        }

        /**
         * 对聚合组中每个行进行迭代,参数个数,类型要和hql中提供的一致
         *
         * 该函数任何时候 return true.
         */
        public boolean iterate(Integer o) {
            if (o != null) {
                state.mSum += o;
                state.mCount++;
            }
            return true;
        }

        /**
         * 因为hsql最后也是转换成mapreduce模型,所以一个聚合组可能存在于多个map中,这个函数对单个map的结果进行汇总
         */
        public UDAFAvgState terminatePartial() {
            // This is SQL standard - average of zero items should be null.
            return state.mCount == 0 ? null : state;
        }

        /**
         * 这个阶段是对应的reduce阶段,对每个map的汇总结果进程再处理
         *
         * 这个函数只会有一个参数,且必须和terminatePartial()函数的返回值类型相同
         */
        public boolean merge(UDAFAvgState o) {
            if (o != null) {
                state.mSum += o.mSum;
                state.mCount += o.mCount;
            }
            return true;
        }

        /**
         * 返回最终结果
         */
        public Double terminate() {
            // This is SQL standard - average of zero items should be null.
            return state.mCount == 0 ? null : Double.valueOf(state.mSum
                    / state.mCount);
        }
    }

    private UDAFExampleAvg() {
        // prevent instantiation
    }

}


将该java文件编译成avj.jar

hive> add jar avg.jar;
hive> create temporary function avg_example as 'UDAFExampleAvg';
hive> select avg_example(t.col1) from t group by id;
hive> drop temporary function helloworld;