org.springframework.transaction.TransactionSystemException: Could not commit Hibernate transaction; nested exception is org.hibernate.TransactionException: Transaction not successfully started
最近在寫(xiě)操作CLOB的過(guò)程中總是報(bào)這個(gè)異常,數(shù)據(jù)去插入進(jìn)去了.
先看看SessionFactory.getCurrentSession與openSession的區(qū)別
1. 如果使用的是getCurrentSession來(lái)創(chuàng)建session的話(huà),在commit后,session就自動(dòng)被關(guān)閉了,
也就是不用再session.close()了。但是如果使用的是openSession方法創(chuàng)建的session的話(huà),
那么必須顯示的關(guān)閉session,也就是調(diào)用session.close()方法。這樣commit后,session并沒(méi)有關(guān)閉
/*2. getCurrentSession的使用可以參見(jiàn)hibernate\hibernate-3.2\doc\tutorial\src項(xiàng)目
3. 使用SessionFactory.getCurrentSession()需要在hibernate.cfg.xml中如下配置:
* 如果采用jdbc獨(dú)立引用程序配置如下:
<property name="hibernate.current_session_context_class">thread</property>
* 如果采用了JTA事務(wù)配置如下
<property name="hibernate.current_session_context_class">jta</property>*/
開(kāi)始用的:
Session session = this.getHibernateTemplate().getSessionFactory().getCurrentSession();
Transaction tran=session.beginTransaction();
好多文章里都說(shuō)只需在Spring配置<bean id="sessionFactory"...---><property name="hibernateProperties"> 中加入 <prop key="hibernate.current_session_context_class">thread</prop>就可以解決,試了沒(méi)用.
修改后的:
Session session = this.getHibernateTemplate().getSessionFactory().openSession();
Transaction tran=session.beginTransaction();
......
finally
{
session.close();
}
問(wèn)題解決