2017-04-03 6 views
0

登録されているカスタムudfを作成しましたが、custom_udf(10)を選択しようとすると次のエラーが表示されます。 ここは私のudfです。それと間違っ: パブリッククラスScalarUdfs {Presto Custom UDF

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(20, IOS); 
     put(42, ANDROID); 
     put(100, WEB); 
    }}; 

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

}

は何も明らかに違って見えるのか?私はそれがパラメータとしてintを与えられた文字列を返すようにしたいと思います。そして、私はjavaとsql型が(Integer - > Integer)、(Slice - > varchar)にマッチすると思います。

おかげ

答えて

1

質問も尋ねたとpresto-usersに答えた:

あなたは(SQL integerはJavaでLongによってバックアップされる)@SqlNullable @SqlType(StandardTypes.INTEGER) Long idを使用する必要があります。

+0

Hey Piotr。うん、私は両方のプラットフォームで尋ねました。それは解決されました、ありがとう:) –

+0

@AceHaidrey私は知っています。将来の来訪者のためにここにも答えます。 –