在执行更新操作,写了如下
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