wearefamulei
2020-04-21 17:33
采纳率: 100%
浏览 904
已采纳

spring设置手动回滚不生效(setRollbackOnly),数据还是入库了。

spring设置手动回滚不生效(setRollbackOnly),数据还是入库了,代码如下。

@Transactional
  public void executeDataMigration() {
    try {
      for (int i = 1; i < 10; i++) {
        insertA(i);
      }

    } catch (Exception e) {
      TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
    }
  }

  public void insertA(int id) {
    String sql = "insert tableA(id, code, name) values (?, ?, ?)";
    dao.executeBySql(sql, new Object[] {id, "123", "小花"});
    String a = null;
    a.toString();
  }

上面代码,捕获异常后加了手动回滚,结果数据还是入库了,请问应该怎么写,才能让数据insertA发生错误后回滚,但是又不能影响for循环的下一次执行。

比如我要循环10次,有2次失败,8次成功,那么数据库的最终数据要为8条,请问怎么能做到呢。

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • 巡山小妖008 2020-04-21 18:47
    已采纳

    开启@EnableAspectJAutoProxy(exposeProxy = true)

    AopContext.currentProxy()).insertA();

    可以参考https://www.cnblogs.com/nxzblogs/p/10503889.html

    已采纳该答案
    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题