首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >JPA Hibernate多对多级联

JPA Hibernate多对多级联
EN

Stack Overflow用户
提问于 2011-02-08 23:42:21
回答 4查看 68.2K关注 0票数 64

我正在使用JPA 2.0和hibernate。我有一个User类和一个Group类,如下所示:

代码语言:javascript
复制
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连接表中删除,但用户本身不会从用户表中删除。

使用上面的代码,当我删除一个组时,只有GROUP表中的行会被删除,而用户在USER_GROUP join表中仍然有一个到被删除组的条目。

如果我将cascade放在User类中,如下所示:

代码语言:javascript
复制
@ManyToMany(cascade=CascadeType.ALL)
@JoinTable(name = "USER_GROUP",
joinColumns =
{
    @JoinColumn(name = "GROUP_ID")
},
inverseJoinColumns =
{
    @JoinColumn(name = "USER_ID")
})
private Set<Group> groupList;

当我删除群组时,用户也将被删除!

有什么方法可以实现我想要的吗?

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4935095

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档