我有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语句
答案 0 :(得分:2)
上面的代码可以做它应该做的事情。 我的问题是在显示用户列表时,Hibernate检测到脏用户集合并将其删除。我最终做的是将关系的所有权更改为Group而不是User,并且所有操作都正常。
答案 1 :(得分:1)
你必须像这样打电话
save(group);
user.getGroups().add(group);
save(user);
你不需要更新实体的另一面,因为它将由hibernate更新。