Spring JdbcTemplate“insert into .. select from ..”无效

时间:2017-09-13 10:11:39

标签: java mysql spring spring-boot jdbctemplate

我正在尝试使用Spring JdbcTemplate执行以下SQL:

INSERT INTO japan_wht.PIVOT_20427002(doc_header_text, value_date, total_amt, is_refund)                    
 (SELECT 
    doc_header_text, DATE(value_date), SUM(LOCAL_CCY_AMT), is_refund
 FROM
    (SELECT 
        *
    FROM
        japan_wht.DATA_20427002
    WHERE IS_REFUND in ('N')
    ) t 
GROUP BY DATE(value_date) , doc_header_text, is_refund)

但是,它不会在数据库表中插入任何内容,也不会抛出任何错误。

当我尝试使用JdbcTemplate执行以下SQL时,它可以工作并在数据库表中插入数据:

INSERT INTO japan_wht.PIVOT_20427002(id, doc_header_text, value_date, total_amt, is_refund) values('1', '1', '2017-12-31', 3000, 'Y');

以下是我执行上述SQL的调用:

jdbcTemplate.update(sqlString);

不确定这里出了什么问题。

2 个答案:

答案 0 :(得分:0)

我不得不求助于简单的JDBC,它起作用了:

Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/mySchema?autoReconnect=true&useSSL=false&rewriteBatchedStatements=true",
    "root", "root");
Statement stmt = conn.createStatement();
int flag = stmt.executeUpdate(sqlString);
LOGGER.info("Flag = {}", flag);

不确定为什么Spring JdbcTemplate无法处理这样的事情!

答案 1 :(得分:0)

您可以使用SortedSet方法。喜欢:

execute