skysnowking
2012-12-02 14:46 阅读 183
已采纳

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();

    }
}

}

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

3条回答 默认 最新

  • 已采纳
    zhouhua0104 想成为工程师的码农 2012-12-02 19:46

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

    点赞 评论 复制链接分享
  • jinnianshilongnian jinnianshilongnian 2012-12-04 12:30

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

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

    点赞 评论 复制链接分享
  • henghanan henghanan 2012-12-10 22:56

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

    tx:attributes







    /tx:attributes
    /tx:advice

    <!-- 配置哪些类的哪些方法参与事务 -->
    <aop:config>
        <aop:advisor advice-ref="transactionAdvice" pointcut="execution(* com.henghanan.service..*.*(..))"/>[/code]
    
    点赞 评论 复制链接分享

相关推荐