Hibernate 错误解决(TransactionException: Transaction not successfully started)

【关键的错误信息】: TransactionException: Transaction not successfully started 和一个doCommit

从该关键字看,是使用Hibernate事务管理器(而不是Spring,下面详细log的绿色字体)处理事务的commit时抛出的,


【具体解决】:

      //下面的代码段会报错

        Session session =  getSessionFactory().getCurrentSession();  
        session.beginTransaction();          //
        String queryString = "update.... "; //具体数据库字段内容的更新
        Query query = session.createQuery(queryString);         
        query.executeUpdate();  
        session.getTransaction().commit(); //应该是这里导致了 org.hibernate.TransactionException: Transaction not successfully started


//改为下面的代码段好了

	Session session =  getSessionFactory().openSession();  
        Transaction tran = session.beginTransaction();   //这么修改后,ok
        String queryString = "update ....";
        Query query = session.createQuery(queryString);  
        query.executeUpdate();  
        tran.commit(); 
        session.close();




【事后诸葛亮】该错误在dao层的一个执行update的语句里面,但该处没有提示错误,而是在调用这个函数的上一级函数要return时抛出的。

1.  可能是session结束时的检查。

2.  没有申请transaction对象,直接使用函数导致了错误?

3.  而且虽然最后报错,但事实上已经成功的修改了数据库(持久化已经完成)。

4.  生搬硬套固然能快速实现,理解透彻才是正道。

5.  这么改可能会影响执行时间,多数据量时可能需要优化。


附:详细的stacktrace:

org.springframework.transaction.TransactionSystemException: Could not commit Hibernate transaction; nested exception is org.hibernate.TransactionException: Transaction not successfully started
at org.springframework.orm.hibernate3.HibernateTransactionManager.doCommit(HibernateTransactionManager.java:660)

Caused by: org.hibernate.TransactionException: Transaction not successfully started
at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:130)
at org.springframework.orm.hibernate3.HibernateTransactionManager.doCommit(HibernateTransactionManager.java:656)
... 77 more


### 解决方案 当遇到 `org.hibernate.TransactionException: JDBC begin transaction failed` 错误时,这通常意味着在尝试启动事务之前,JDBC 连接已经出现问题。此问题可能由多种因素引起,包括但不限于配置不正确、资源不可用或网络中断。 #### 配置检查 确保应用程序中的 Hibernate 和数据源配置文件设置无误。特别是要确认数据库方言 (`hibernate.dialect`) 已经被正确定义[^1]: ```properties spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL8Dialect ``` 如果未指定该属性,则可能会抛出异常 `Access to DialectResolutionInfo cannot be null when 'hibernate.dialect' not set`. #### 使用连接池优化性能并提高稳定性 引入合适的数据库连接池可以有效缓解因频繁建立新连接而导致的问题。常见的开源解决方案有 HikariCP 或者 Apache Commons DBCP 等工具[^2]。以下是基于 Spring Boot 应用程序的一个简单例子来集成HikariCP: ```yaml spring: datasource: type: com.zaxxer.hikari.HikariDataSource hikari: maximumPoolSize: 10 minimumIdle: 5 idleTimeout: 30000 connectionTestQuery: SELECT 1 FROM DUAL ``` 通过上述方式调整最大/最小空闲连接数以及超时时间参数可以帮助维持稳定的连接状态,并减少由于瞬态故障引发的错误几率。 #### 日志记录与监控 增强日志级别以便更好地追踪潜在问题所在位置。对于生产环境而言,建议启用详细的 SQL 执行日志输出,这样可以在发生异常时快速定位根源。 ```java logging.level.org.springframework.transaction=DEBUG logging.level.org.hibernate.SQL=DEBUG ``` 此外,考虑部署专业的 APM(Application Performance Management) 平台用于实时监测应用表现情况,及时发现并处理可能出现的服务降级事件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值