我正在使用JPA 2.0并休眠。我有一个用户类和一个组类,如下所示:
public class User implements Serializable {
@Id
@Column(name="USER_ID")
private String userId;
@ManyToMany
@JoinTable(name = "USER_GROUP",
joinColumns = {
@JoinColumn(name = "GROUP_ID")
},
inverseJoinColumns = {
@JoinColumn(name = "USER_ID")
}
)
private Set<Group> groupList;
//get set methods
}
public class Group
{
@Id
@Column(name="GROUP_ID")
private String groupId;
@ManyToMany(mappedBy="groupList")
private Set<User> memberList;
//get set methods
}
然后,我创建一个用户和组,然后将该用户分配给该组。
我想要的是删除组时(当然),该组将被删除,并且该组具有的所有用户-组关系将自动从USER_GROUP连接表中删除,但用户本身不会从USER表。
使用上面的代码,当我删除组时,只有GROUP表中的行将被删除,并且用户在USER_GROUP连接表中仍将具有删除组的条目。
如果我像这样在User类中放置层叠:
@ManyToMany(cascade=CascadeType.ALL)
@JoinTable(name = "USER_GROUP",
joinColumns =
{
@JoinColumn(name = "GROUP_ID")
},
inverseJoinColumns =
{
@JoinColumn(name = "USER_ID")
})
private Set<Group> groupList;
当我删除组时,用户也将被删除!
有什么方法可以实现我想要的吗?
最佳答案
映射的方式是User
是关系的管理方,因此它将负责更新联接表。
将JoinTable
映射从User
更改为Group
,并设置groupList
的User
属性为mappedBy
属性。这会将组更改为关系的管理方,并向该组进行持久性/更新调用以管理联接表。
但是请注意,您将不能简单地向用户添加组,保存用户并继续,而必须将用户添加到组并保存组以查看更改,但是希望有双向多对多关系,您无论如何都会密切管理这一关系。