内容简介:MyBatis Batch Update Exception使用foreach批量update出错
通过MyBatis框架,对 Mysql 数据库做批量更新,对于的Mapper.xml配置:
<update id="updateTestcaseNodeBatch" parameterType="List"> <foreach collection="list" item="nodeVO" separator=";"> UPDATE testcase_node <set> name=#{nodeVO.name}, version=#{nodeVO.version}, description=#{nodeVO.description}, last_modify_user=#{nodeVO.createUser}, last_modify_time=#{nodeVO.createTime} </set> <where> object_id=#{nodeVO.objectId} AND root_id=#{nodeVO.rootId} </where> </foreach> </update>
异常信息:
### The error may involve com.hirain.testmanagement.mapper.TestcaseNodeMapper.updateTestcaseNodeBatch-Inline ### The error occurred while setting parameters ### SQL: UPDATE testcase_node SET name=?, version=?, description=?, last_modify_user=?, last_modify_time=? WHERE object_id=? AND root_id=? ; UPDATE testcase_node SET name=?, version=?, description=?, last_modify_user=?, last_modify_time=? WHERE object_id=? AND root_id=? ### Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '; UPDATE testcase_node SET name='Türstatus', version=4, ' at line 8 ; bad SQL grammar []; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '; UPDATE testcase_node SET name='Türstatus', version=4, ' at line 8 at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:233)
2 排除过程
- 仔细检查 map文件 和数据库表字段没有错误;【正常】
- 将生产的SQL,贴到Mysql Client端执行;【正常】
- 再次检查JDBC驱动链接URL;【不正常】
3 解决问题
最终结果是
因为配置的 mysql jdbc链接字符串 默认不支持一次性执行多个 sql 语句
;但是在我们的 update map中需要执行多个 update语句。最后加上参数 "allowMultiQueries" 设置为true 如下:
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true" />
4 总结问题
问题解决!关键是解决问题的思路,由易到难,有外到内,确保最基本的配置不出问题。
以上所述就是小编给大家介绍的《MyBatis Batch Update Exception使用foreach批量update出错》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 使用css时,可能会出错的两个地方
- webpack4.x使用UglifyJS出错问题
- 如何避免空指针出错?
- 如何避免特效渲染出错?
- OmniROM:“Flex checkpolicy”出错
- Python安装软件包出错
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C语言算法速查手册
程晓旭、耿鲁静、张海、王勇 / 2009-10 / 49.00元
《C语言算法速查手册》用C语言编写了科研和工程中最常用的166个算法,这些算法包括复数运算、多项式的计算、矩阵运算、线性代数方程组的求解、非线性方程与方程组的求解、代数插值法、数值积分法、常微分方程(组)初值问题的求解、拟合与逼近、特殊函数、极值问题、随机数产生与统计描述、查找、排序、数学变换与滤波等。同时结合这些算法列举了将近100个应用实例,对其进行验证和分析。 《C语言算法速查手册》适......一起来看看 《C语言算法速查手册》 这本书的介绍吧!