错误:
Caused by: org.hibernate.ObjectDeletedException: deleted object would be re-saved by cascade (remove deleted object from associations)
在service业务层添加事务注解@Transactional
//删除用户组
public boolean delUserGroup(GroupVo groupVo){
String groupname = groupVo.getGroupname();
SystemGroup group = null;
if(groupname!=null){
group = systemGroupDao.getSystemGroupByName(groupname);
}
if(group == null){
return false;
}
// systemGroupDao.delSystemGroupActionByGroupName(group);
group.delGroupAction();
systemGroupDao.delete(group);
return true;
}
事务开始到结束 都是同一session处理,导致查询出来的语句的状态还在关联session中[associations]
必须删除事务标签
另一种情况
class:ActionRole
@ManyToOne
@JoinColumn(name = "actionid")
private SystemAction action;
@ManyToOne
@JoinColumn(name = "roleid")
private SystemRole role;
class:SystemRole
@OneToMany(mappedBy = "role", cascade = CascadeType.ALL,fetch=FetchType.EAGER)
private Set<SystemGroupAction> groupActions;
role.getGroupActions().clear();
systemGroupDao.delSystemRole(role);
本文探讨了在使用Hibernate框架进行级联删除操作时遇到的ObjectDeletedException异常问题,并提供了两种解决方案:一种是在Service层使用@Transactional注解处理事务,另一种是调整实体间的关联关系和级联类型。
2858

被折叠的 条评论
为什么被折叠?



