spring+hibernate事务处理

<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

<tx:annotation-driven transaction-manager="txManager" />

@Transactional
public class ProvinceDAO extends HibernateDaoSupport implements ProvinceDAOImpl {
public void updatePinYinById(List list) {
for (Object object : list) {
Province province = (Province) object;
String hql = "UPDATE Province p SET p.pinyin=:pinyin WHERE p.id=:id ";
Query query = this.getHibernateTemplate().getSessionFactory().getCurrentSession().createQuery(hql);
query.setParameter("id", province.getId());
query.setParameter("pinyin", province.getPinyin());
query.executeUpdate();

    }
}

}

我在批量更新时,会出错。但是不回滚,

spring回滚默认是运行时异常回滚的,如果你想要只要发生异常就回滚的话,需要手动配置
@Transactional(RollbackFor=Exception.class)

建议把
this.getHibernateTemplate().getSessionFactory().getCurrentSession().createQuery(hql);
改成回调,如
this.getHibernateTemplate().execute(new HibernateCallback)

2、你使用的是么数据库? 如果是mysql 保证引擎不是myISAM

1、事务处理不要放在dao
2、推荐用声明式事务
[code="java"]<!-- 配置事务传播特性 -->

tx:attributes







/tx:attributes
/tx:advice

<!-- 配置哪些类的哪些方法参与事务 -->
<aop:config>
    <aop:advisor advice-ref="transactionAdvice" pointcut="execution(* com.henghanan.service..*.*(..))"/>[/code]