9

我有产生线程#2的主线程,它在主线程中使用相同的休眠会话。线程 #2 每隔几分钟就会执行一次“select 1”以保持数据库连接处于活动状态,因为主线程的进程运行时间很长。一旦主线程完成了处理,它就会调用一个提交,但我得到了错误:

Caused by: org.hibernate.TransactionException: JDBC commit failed
    at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:161)
    at org.springframework.orm.hibernate3.HibernateTransactionManager.doCommit(HibernateTransactionManager.java:655)
    ... 5 more
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

在主线程中,它创建成功提交的内部事务,它只是在提交时抛出此错误的外部事务。我看不出有什么可以改变自动提交布尔值。在我引入第二个线程以保持连接处于活动状态之前,从未发生过此错误。

4

2 回答 2

6

尽管我认为您应该认真重新考虑使用 Hibernate 的方式,但您可以通过relaxAutoCommit在其 URL 中向 JDBC 驱动程序添加一个参数来绕过这个问题。

MySQL 文档中的详细信息:

relaxAutoCommit

If the version of MySQL the driver connects to does not support transactions, still allow calls to commit(), rollback() and setAutoCommit() (true/false, defaults to 'false')?

Default: false

Since version: 2.0.13

来源:https ://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-configuration-properties.html

于 2011-03-10T16:46:14.950 回答
4

在博客中找到了答案,解决方案引用:

在 jdbc url 中设置属性relaxAutoCommit=true 解决了我们的问题。

jdbc:mysql://dbserver/database?rewriteBatchedStatements=true&relaxAutoCommit=true

当然博客是另一种场景,直接跳过“rewriteBatchedStatements=true”部分

于 2014-04-15T15:26:04.067 回答