首页 > 系统服务 > 详细

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

时间:2014-05-06 22:43:11      阅读:549      评论:0      收藏:0      [点我收藏+]

【关键的错误信息】: 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


Hibernate 错误解决(TransactionException: Transaction not successfully started),布布扣,bubuko.com

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

原文:http://blog.csdn.net/do_script/article/details/25131655

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!