java SSM多操作注解回滚

在业务操作时难免会遇到一个业务多操作,会用到事物回滚这里写了一个简单的多操作失败事物回滚案例

在这之前你需要在你的applicationContext-mybatis.xml中配置:

<!-- 事务管理 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>     

下面这段代码是一个简单删除操作,删除的时候传入的Product类的对象pro只赋值了id其他字段并未赋值在

  • 先写了一个删除操作

  • 后面跟了一个新增商品的操作(这个操作很明显是错误的会因为对象属性未赋值插入错误)

  • 在多操作是用 try catch 包裹起来,在catch 中如果出现错误调用 TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); 进行多操作事物回滚

        @Transactional
    @Override
    public boolean del(Product pro) {
        //多操作回滚案例
        boolean boo=false;
        try{
            System.out.println("开始");
            pm.del(pro);
            pm.add(pro);
            boo=true;
            
        }catch(Exception e){
            System.out.println("删除异常");
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();//就是这一句了,加上之后,如果doDbStuff2()抛了异常,                                                                                   
             //doDbStuff1()是会回滚的  
             System.out.println("操作回滚");
        }
        return boo;
    }

猜你喜欢

转载自www.cnblogs.com/userzf/p/9060149.html