日期:2014-05-20  浏览次数:20693 次

hibernate 双向关联的问题 小弟求解
@Entity
@Table(name="ch")
public class Group {
private int id;
private String name;
private Set<User> users = new HashSet<User>();
@OneToMany(mappedBy="group")
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

@Entity
@Table(name="cz")
public class User {
private int id;
private Group group;
@ManyToOne(cascade=CascadeType.ALL)
public Group getGroup() {
return group;
}
public void setGroup(Group group) {
this.group = group;
}
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

private String name


测试类

public void testSaveUser() {
User u = new User();
u.setName("u1");
Group g = new Group();
g.setName("g1");
u.setGroup(g);
Session s = sessionFactory.getCurrentSession();
s.beginTransaction();
s.save(u);
s.getTransaction().commit();
}

为何加到表里 一个ID 是1 一个ID 是2? 应该都是1才对啊 求解

------解决方案--------------------
第一,我没明白你说的是什么意思?哪个ID是1,哪个ID是2?Group和User都有个自的ID。
第二,双向关联,你只做了u.setGrout(g);但是你g.setUsers(Set<User> users)呢?双向关联啊。

级联保存一般是保存主表,级联保存子表。s.save(u);你用子表级联保存主表啊?一般不带这么干的啊。