Odps执行SQL报错,提示Please set odps.sql.type.system.odps2=true to use it.

Odps执行SQL报错,提示Please set odps.sql.type.system.odps2=true to use it.或提示Please add put { "odps.sql.submit.mode" : "script"} for multi-statement query in settings的解决方案

odps错误信息

java 复制代码
AnonymousSQLTask--ODPS-0130071:[1,474] Semantic analysis exception - DATE type is not enabled in current mode. 
Please set odps.sql.type.system.odps2=true to use it.
ODPS-0130071:[1,1165] Semantic analysis exception - DATE type is not enabled in current mode. 
Please set odps.sql.type.system.odps2=true to use it.

// 或提示下面的错误信息
com.aliyun.odps.OdpsException: 
Please add put { "odps.sql.submit.mode" : "script"} for multi-statement query in settings

解决方案:

在执行task前,将上面的配置信息增加进hints中

java 复制代码
public Instance sqlRunTable(String sql) throws OdpsException {
    Map<String, String> hints = new HashMap<>();
    hints.put("odps.sql.submit.mode", "script");
    hints.put("odps.sql.type.system.odps2", "true");
    SQLTask.setDefaultHints(hints);
    Instance instance = SQLTask.run(odps, sql);
    if (!instance.isSync()) {
        instance.waitForSuccess();
    }
    if (!instance.isSuccessful()) {
        log.error("ODPS执行SQL语句失败!{}", sql);
        for (String key : instance.getTaskResults().keySet()) {
            log.error("{}--{}", key, instance.getTaskResults().get(key));
        }
    }
    return instance;
}
相关推荐
成为大佬先秃头8 小时前
前后分离项目:整合JWT+Shiro
java·springboot·shiro·jwt
y = xⁿ8 小时前
【Leet Code 】滑动窗口
java·算法·leetcode
day day day ...8 小时前
MyBatis条件误写引发的查询条件污染分析与防范
java·服务器·tomcat
hrhcode8 小时前
【java工程师快速上手go】一.Go语言基础
java·开发语言·golang
2601_950703949 小时前
Spring IoC入门实战:XML与注解双解
java
带刺的坐椅9 小时前
Snack JSONPath 项目架构分析
java·json·java8·jsonpath
妙蛙种子3119 小时前
【Java设计模式 | 创建者模式】 原型模式
java·开发语言·后端·设计模式·原型模式
Lyyaoo.9 小时前
【JAVA基础面经】线程的状态
java·开发语言
Hello小赵9 小时前
C语言如何自定义链接库——编译与调用
android·java·c语言
希望永不加班9 小时前
SpringBoot 配置绑定:@ConfigurationProperties
java·spring boot·后端·spring