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
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐


所有评论(0)