spring事务回滚:当同时需要在多个数据表插入数据时,一个出错如何实现全部回滚

目前我的做法是,将每个插入方法全部放在一个带有事务的Servcie方法里面,以至于所有数据库操作全部位于一个事务里面。
Servcie层事例:

	@Transactional
	public boolean UserRegister(ESysUser entity) {
		try {
			//插入ESysUser
			eSysUserDao.insert(entity);
			//插入ESysUserInfo
			if(entity.getId() == null) {
				return false;
			}else {
				ESysUserInfo eSysUserInfo = new ESysUserInfo();
				eSysUserInfo.setUserId(entity.getId());
				//eSysUserInfo.setUserName(entity.getUserLogin());
				eSysUserInfo.setRealName(entity.getUserLogin());
				eSysUserInfo.setUserStatus(2);
				eSysUserInfoDao.insert(eSysUserInfo);
				return true;
			}
		} catch (Exception e) {
			// TODO: handle exception
			TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
			log.error(e.getMessage(), e);
			return false;
		}
	}

这里TransactionAspectSupport.currentTransactionStatus()获得当前事务,实现回滚。
Controller直接调用Service层这个方法。
注:如果出现“No transaction aspect-managed TransactionStatus in scope”异常
可参考这里https://www.iteye.com/blog/bugyun-2434939

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值