java - Spring JdbcTemplate "insert into.. select from.."不工作

标签 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);

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

最佳答案

我不得不求助于普通的 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 不能处理这样的事情!

关于java - Spring JdbcTemplate "insert into.. select from.."不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46194762/

相关文章:

java - 谷歌API错误: Null Pointer Exception (Is Google API recently made un available by google?)

mysql - 如何在另一台计算机上安装我的 MAMP 数据库?

Mysql join 4个表可以在一个查询中完成吗

java - 如何使用 JUnit 5 在 Spring Boot 中捕获 Hibernate ConstraintViolationException(或 Spring DataIntegrityViolationException?)

java - 无法反序列化 HTTP 调用程序远程服务的结果 [...];嵌套异常是 java.lang.ClassNotFoundException :

java - Spring JPA + Hibernate 搜索 : How update the Search Index(Lucene) only?

java - 您可以通过对象条件而不是索引从数组中删除对象吗?

Java Scanner 类 - 无法退出 while 循环

java - 将 JSF .xhtml 文件映射到无扩展名

mysql - fat free crm安装mysql报错