JDBC 提交失败 Can‘t call commit when autocommit=true

时间:2024-10-16 07:12:09

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 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!