ManyToMany关系不在关联表中更新/插入

时间:2012-05-05 20:09:07

标签: hibernate gwt jpa many-to-many

我有2个与ManyToMany关系相关的Hibernate对象Group和User。

我使用以下映射

Group.java

private Set<User> users = new HashSet<User>(0);

...

@ManyToMany(cascade = CascadeType.ALL)  
@JoinTable(name = "user_group",
joinColumns = { @JoinColumn(name = "GROUP_ID") },
inverseJoinColumns = { @JoinColumn(name = "USER_ID") })
public Set<User> getUsers() {
    return this.users;
}
...

User.java

private Set<Group> groups = new HashSet<User>(0);

...


@ManyToMany(mappedBy = "users") 
public Set<Group> getGroups() {
    return this.groups;
}

...

DAO.java

public User addUserToGroup (Integer groupId , Integer  userId){
    Group group = (Group) getBeanById(groupId, Group.class); //Here I get the right group
    User user = (User) getBeanById(userId, User.class);//Here I get the right user
    group.getUsers().add(user);
    user.getGroups().add(group);
    save(group);        
    return user;
}

保存方法

public EntityBase save(EntityBase transientInstance) {
    Session session = HibernateUtil.getCurrentSession();
    log.debug("persisting  instance");
    try {
        session.saveOrUpdate(transientInstance);
        log.debug("persist successful");
        return transientInstance;
    } catch (RuntimeException re) {
        log.error("save failed", re);
        throw re;
    }
}

我的问题是当我将用户添加到groupe时,没有记录添加到关联表user_group

注意:在过滤器Servlet中调用begin和commit语句

2 个答案:

答案 0 :(得分:2)

上面的代码可以做它应该做的事情。 我的问题是在显示用户列表时,Hibernate检测到脏用户集合并将其删除。我最终做的是将关系的所有权更改为Group而不是User,并且所有操作都正常。

答案 1 :(得分:1)

你必须像这样打电话

save(group); 
user.getGroups().add(group);
save(user);

你不需要更新实体的另一面,因为它将由hibernate更新。