Hive jdbc执行seelct 语句时报 return code 1 from org.apache.hadoop.hive.ql.exec.mr.MapRedTask

参考1
解决方法:
         对HIVE表进行条件过滤,必须要以partition为首要条件。
如:select distinct hdate from t_stage_access where hdate like '2014-07-%' and dt='2014-07-28'
hdate是partition。
不行


参考2
解决方式:用hive jdbc建表,用hive jdbc执行操作。

用hive shell建表,用hive jdbc执行操作可能会导致权限问题,引起以上两个错误。在删除原表,改用jdbc建表之后,异常解决了。

不行

最终找了我们的DBA,hive报错:

没有设置下队列,不允许提交到default队列中

2017-06-20T17:05:26,685ERROR [HiveServer2-Background-Pool: Thread-180955]: exec.Task(SessionState.java:printError(1038)) - Job Submission failed with exception'java.io.IOException(Failed

to run job : Userhduser1701 cannot submit applications to queue root.default)'

java.io.IOException:Failed to run job : User hduser1701 cannot submit applications to queueroot.default


原来是代码里没有指定队列,默认访问默认队列,没有权限                        

 //set queue

 stmt.execute(mysql[0]);

 res = stmt.executeQuery(mysql[1]);

Set mapreduce.job.queuename=queue_xxx_01;


完美解决。。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值