-
执行sql中使用udf函数报数组下标越界异常:
hue中报错为:
Error while processing statement: FAILED: Execution Error, return code 2 from org.apache.hadoop.hive.ql.exec.mr.MapRedTask。
log日志报错为:
Caused by: java.lang.ArrayIndexOutOfBoundsException: 38
at org.apache.hadoop.hive.ql.exec.vector.udf.VectorUDFAdaptor.evaluate(VectorUDFAdaptor.java:117)
at org.apache.hadoop.hive.ql.exec.vector.VectorSelectOperator.processOp(VectorSelectOperator.java:124)
... 13 more
解决办法: 执行(仅对当前用户有效)
set hive.vectorized.execution.enabled=false;
set hive.vectorized.execution.reduce.enabled=false;
-
函数明明创建成功却报 invalid function错误:
udf函数是有作用范围的,
创建时没有指定db,默认使用的default,
给指定db创建UDF函数的方式是:在创建函数时,函数名前拼接'db名称.',即:db名称.+UDF函数名,例如:rfmp_db.3des_encrypt;
贴上我的创建语句供参考理解:
CREATE FUNCTION rfmp_db.3des_encrypt AS 'com.chinaums.udf.SecurityUDF' using jar 'hdfs://nameservice1:8020/user/hive/udf/encrypt-3des-1.0.jar';