目前我的做法是,将每个插入方法全部放在一个带有事务的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