在执行更新操作,写了如下
final String cardid = udto.getCarid0(); final String scdlsj = udto.getScdlsj(); final String bcdlsj = udto.getBcdlsj(); SessionFactory sf = hibernateTemplate.getSessionFactory(); Session s = sf.getCurrentSession(); //用spring管理了事务,不用写beginTransaction() //s.beginTransaction(); s.createQuery("update User u set u.scdlsj=:scdlsj,u.bcdlsj=:bcdlsj where carid0 = :carid0") .setString("scdlsj", scdlsj) .setString("bcdlsj", bcdlsj) .setString("carid0", cardid).executeUpdate(); //s.getTransaction().commit();因为在spring中已经配置了事务,这里在写beginTransaction(),就会报
Transaction not successfully started异常
将其代码注释,如上面代码
附上spring中的事务配置
<!-- 事务 --> <bean id="myTxManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <aop:config> <aop:pointcut id="bussinessService" expression="execution(public * com.wuqn.login.dao.impl..*.*(..))" /> <aop:advisor advice-ref="txAdvice" pointcut-ref="bussinessService" /> </aop:config> <tx:advice id="txAdvice" transaction-manager="myTxManager"> <tx:attributes> <tx:method name="exists" read-only="true" /> <tx:method name="add" propagation="REQUIRED" /> <tx:method name="load*" propagation="REQUIRED" /> <tx:method name="set*" propagation="REQUIRED" /> </tx:attributes> </tx:advice>或者将SessionFactory.getCurrentSession() 改为 SessionFactory.OpenSession();
它们的区别 详见http://blog.csdn.net/woisnong/article/details/7423986