我为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}} |
+----------------------------------------------------------------------------------------------------------------------+--+
答案 0 :(得分:1)
当开源项目缺乏文档时,需要访问实际的源代码本身才能看到真正的答案。因此,对于各种基于时间的数据类型,最好阅读源代码中的代表性示例。这个特殊的课程很好地说明了用法。