hive中创建udf函数常见问题及解决办法

  • 执行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';

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值