spring事务回滚的demo

1.contrller层代码

@RestController
@RequestMapping("transactionnalDemo")
public class TransactionnalDemoController {

    @Autowired
    TransactionnalDemoService transactionnalDemoService;

    @RequestMapping(value = "/insert", method = RequestMethod.GET)
    public void insert() throws Exception {
        try {
            int i = transactionnalDemoService.saveTransactionnalDemo();
            System.out.println("contrell层返回值:"+i);
        } catch (Exception e) {
            System.out.println("contrell层异常信息:"+e.getMessage());
        }
    }
}

2.service层代码

@Service
public class TransactionnalDemoServiceImpl implements TransactionnalDemoService {

    @Autowired
    TransactionnalDemoDao transactionnalDemoDao;

    @Override
    @Transactional
    public int saveTransactionnalDemo() {
    //14,15,16数据库中以存在,17数据库不存在所以更新返回0出现异常抛出异常回滚
        String[] numberStrin = {"14","15","16","17"};
        for(int i = 0;i<numberStrin.length;i++) {
            //transactionnalDemoDao.saveTransactionnalDemo(numberStrin[i]);
            int k = transactionnalDemoDao.updateTransactionnalDemo(numberStrin[i]);
            System.out.println("返回值:"+k);
            if(k == 0){
              throw new RuntimeException("新增异常");
            }
        }
        return 1;
    }
}

3.dao层代码

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dao.TransactionnalDemoDao">
    <!-- 保存服务用户信息 -->
    <insert id="saveTransactionnalDemo" >
      insert into transactionnal_demo(transactionnal_number) values(#{transactionnalNumber})
    </insert>
    <update id="updateTransactionnalDemo">
        update transactionnal_demo set transactionnal_number = 3 where id = #{id}
    </update>
</mapper>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值