java SSM多操作注解回滚

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

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

<!-- 事务管理 -->
        <bean >
                <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;
        }