适用于UDF的Hive DATE和TIMESTAMP的数据类型

时间:2017-03-15 20:53:15

标签: java hive bigdata

我为Hive项目编写了一个新的UDF,但返回类型不是DATE对象,而是一个奇怪的结构。什么是正确的返回类型?

@Description(name = "udf_good_date", value = "_FUNC_(datestring):DATE", extended = "")
@UDFType(deterministic = true, stateful = false)
public class GoodDateAsDateUDF extends UDF {

    public Date evaluate(String a) {
        return Utils.getGoodDate(a);
    }

}

试一试:

select default.udf_good_date('10/20/1983);

奇怪的是:

+----------------------------------------------------------------------------------------------------------------------+--+
|                                                         _c0                                                          |
+----------------------------------------------------------------------------------------------------------------------+--+
| {"fasttime":125733600000,"cdate":{"cachedyear":1983,"cachedfixeddatejan1":720259,"cachedfixeddatenextjan1":720624}}  |
+----------------------------------------------------------------------------------------------------------------------+--+

1 个答案:

答案 0 :(得分:1)

当开源项目缺乏文档时,需要访问实际的源代码本身才能看到真正的答案。因此,对于各种基于时间的数据类型,最好阅读源代码中的代表性示例。这个特殊的课程很好地说明了用法。

https://github.com/apache/hive/blob/ff67cdda1c538dc65087878eeba3e165cf3230f4/ql/src/java/org/apache/hadoop/hive/ql/udf/UDFHour.java