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

你可能感兴趣的:(后台开发)