Presto自定义UDF

原学程将引见Presto自界说UDF的处置办法,这篇学程是从其余处所瞅到的,而后减了1些海外法式员的疑问与解问,愿望能对于您有所赞助,佳了,上面开端进修吧。

Presto自定义UDF 教程 第1张

成绩描写

我曾经创立了1个已注册的自界说UDF,但是当我测验考试选择CUSTOM_UDF(一0)时,支到以下毛病:
Exact implementation of BasicPlatform do not match expected java types
这是我的UDF,我仿佛没有晓得它出了甚么成绩:
大众类ScalarUdf{

private ScalarUdfs() {};

@ScalarFunction("basic_platform")
@SqlType(StandardTypes.VARCHAR)
public static Slice BasicPlatform(@SqlNullable @SqlType(StandardTypes.INTEGER) Integer id) {
 final Slice IOS = Slices.utf8Slice("iOS");
 final Slice ANDROID = Slices.utf8Slice("Android");
 final Slice WEB = Slices.utf8Slice("Web");
 final Slice OTHER = Slices.utf8Slice("Other");
 final Map<Integer, Slice> PLATFORM_MAP = new HashMap<Integer, Slice>() {{
  put(二0, IOS);
  put(四二, ANDROID);
  put(一00, WEB);
 }};

 if (id == null || !PLATFORM_MAP.containsKey(id)) {
  return OTHER;
 }
 return PLATFORM_MAP.get(id);
}

}

有甚么甚么显著的成绩?我愿望它前往1个给定int作为参数的字符串,而且我以为Java以及SQL典型婚配(Integer->Integer),(Slice->varchar)。

感谢

推举谜底

该成绩也在presto-users被问问:

您必需应用@SqlNullable @SqlType(StandardTypes.INTEGER) Long id(由于在Java中SQLintegerLong支撑)。

佳了闭于Presto自界说UDF的学程便到这里便停止了,愿望趣模板源码网找到的这篇技巧文章能赞助到年夜野,更多技巧学程不妨在站内搜刮。