同一数据库多表事务回滚

记录、避免遗忘

    @Autowired
    private UserInfoPOMapper userInfoPOMapper;

    // 开启事务(必须有)
    @Transactional
    @Override
    public BusinessResponse multiTableRollBack() {
        // A数据库-插入一条数据
        BusinessResponse<UserAccountPO> testA = insertA();
        if (!testA.success()) {
            return AuthBusinessResponse.fail(testA.getRt_code(), testA.getRt_msg());
        }
        // B数据库-插入一条数据
        BusinessResponse<UserInfoPO> testC = insertB();
        if (!testC.success()) {
            return AuthBusinessResponse.fail(testC.getRt_code(), testC.getRt_msg());
        }
        // 查询成功
        BusinessResponse<UserAccountPO> testB = queryASuccess();
        if (!testB.success()) {
            return AuthBusinessResponse.fail(testB.getRt_code(), testB.getRt_msg());
        }
        // 查询失败
        BusinessResponse<UserAccountPO> testD = queryAError();
        if (!testD.success()) {
            // 手动回滚
            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
            return AuthBusinessResponse.fail(testD.getRt_code(), testD.getRt_msg());
        }
        return BusinessResponse.ok(null);
    }

    /**
     * A数据库-插入一条数据
     */
//    @Transactional(可有可无)
    public BusinessResponse<UserAccountPO> insertA() {
        UserAccountPO userAccountPO = new UserAccountPO();
        userAccountPO.setLoginName("abc123");
        userAccountPO.setLoginPassword("123456");
        int i = userAccountPOMapper.insertSelective(userAccountPO);
        if (i != 1) {
            return BusinessResponse.fail(10000, "插入失败");
        }
        return BusinessResponse.ok(null);
    }

    /**
     * B数据库-插入一条数据
     */
//    @Transactional(可有可无)
    public BusinessResponse<UserInfoPO> insertB() {
        UserInfoPO userInfoPO = new UserInfoPO();
        userInfoPO.setAccountId(666);
        userInfoPO.setNickname("昵称");
        int i = userInfoPOMapper.insertSelective(userInfoPO);
        if (i != 1) {
            return BusinessResponse.fail(10000, "插入失败");
        }
        return BusinessResponse.ok(null);
    }

    /**
     * 查询一条[存在的]数据
     */
//    @Transactional(可有可无)
    public BusinessResponse<UserAccountPO> queryASuccess() {
        UserAccountPO userAccountPO = userAccountPOMapper.selectByPrimaryKey(2);
        if (ObjectUtils.isEmpty(userAccountPO)) {
            return BusinessResponse.fail(20000, "查询不到");
        }
        return BusinessResponse.ok(userAccountPO);
    }

    /**
     * 查询一条[不存在的]数据
     */
//    @Transactional(可有可无)
    public BusinessResponse<UserAccountPO> queryAError() {
        UserAccountPO userAccountPO = userAccountPOMapper.selectByPrimaryKey(6);
        if (ObjectUtils.isEmpty(userAccountPO)) {
            return BusinessResponse.fail(20000, "查询不到");
        }
        return BusinessResponse.ok(userAccountPO);
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值