JDBC 提交失败 Can’t call commit when autocommit=true
SpringBoot、MyBatis、MySQL
本文可能是一个解决方案,不保熟,不保证一定有效,仅仅是提供一个思路。
背景
业务系统的同步服务在一次异常断电重启后,不能正常启动,报错,本文是其中出现的问题之一。
问题描述
错误信息大概如下:
Caused by: java.sql.SQLException: Can't call commit when autocommit=true
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:930)
at com.mysql.jdbc.ConnectionImpl.commit(ConnectionImpl.java:1602)
at org.hibernate.transaction.JDBCTransaction.commitAndResetAutoCommit(JDBCTransaction.java:170)
at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:146)
... 6 more
原因分析
- 启用自动提交后,即 autoCommit = true 的情况下,再次调用commit()、rollback()时,往往会报这个异常。
解决方案
- 使用connection.setAutoCommit(false) (参考****博客,未测试)
- 在JDBC的URL里加上 relaxAutoCommit = true 参数 (参考评论-grem)
声明:本文使用八爪鱼rpa工具从gitee自动搬运本人原创(或摘录,会备注出处)博客,如版式错乱请评论私信,如情况紧急或久未回复请致邮 xkm.0jiejie0@qq.com 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!