博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SpringJDBC的JdbcTemplate在MySQL5.7下不支持子查询的问题
阅读量:6321 次
发布时间:2019-06-22

本文共 1414 字,大约阅读时间需要 4 分钟。

org.springframework.jdbc.BadSqlGrammarException: PreparedStatementCallback; bad SQL grammar [   SELECT * FROM `AAAA` Z LEFT JOIN  (SELECT * FROM `BBBB`         where targetdate >= 20150901) M  ON Z.TargetDate = M.TargetDate...]; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'DB名.*' doesn't exist        at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:231)        at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:73)        at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:645)        at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:680)        at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:712)        at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:722)        at org.springframework.jdbc.core.JdbcTemplate.queryForRowSet(JdbcTemplate.java:859)

从上面的ErrorLog中可以看出,通过JdbcTemplate的queryForRowSet方法执行包含有子查询的SQL语句时发生异常。

SpringJDBC版本为4.2.5-Release,相同的语句在测试环境的MySQL上执行无误,但在生产环境的MySQL5.7版本中,发生上述异常。

 

排错过程:

1,针对常见的表名大小写问题进行调查发现MySQL配置无误。

2,修改SQL去除子查询后执行无误。

3,直接通过phpMyAdmin执行该条包含子查询的语句也执行无误。

4,切换为JavaJDBC实现代码后,该包含子查询的语句也执行无误。

 

由此大致可以推断是JdbcTemplate本身的问题。

 

具体原因需要深入到SpringJDBC4.2.5的源码来调查。

 

转载于:https://www.cnblogs.com/csliwei/p/6688931.html

你可能感兴趣的文章
小组项目冲刺第四天的个人总结
查看>>
Mybatis入门
查看>>
2019.2.15 t2
查看>>
17、ListView & GridView
查看>>
java中的继承与oc中的继承的区别
查看>>
Django之ORM
查看>>
布局的一点总结
查看>>
根据条件更改水晶报表的背景颜色
查看>>
c程序设计语言第一章5
查看>>
WinForm 对话框、流
查看>>
019-直接利用Socket/TCP开发网络游戏二
查看>>
Java集合之ArrayList
查看>>
python的标准数据类型
查看>>
Android 那些年踩过的坑
查看>>
消息handler message 线程通信 空消息
查看>>
scrapy 按顺序抓取text内容
查看>>
软技能(面试)1
查看>>
The 18th Zhejiang University Programming Contest Sponsored by TuSimple -C Mergeable Stack
查看>>
【linux】保存屏幕日志log
查看>>
记一道经典前端题
查看>>