jan*_*jan 4 java sql mapping hibernate
我有两个非常简单的对象,一个对象应该在一个集合中以"一对多"关系包含另一个对象.对象在数据库中正确插入,但"children"表中的外键始终为"null".
我无法弄清楚原因:
这是测试对象,它将子项保存在其集合中:
@Entity
@Table(name="test")
public class TestObj {
public TestObj(){}
private Long id;
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
private Set<Children> children = new HashSet<Children>();
@OneToMany(mappedBy = "testObj", cascade = CascadeType.ALL)
public synchronized Set<Children> getChildren() {
return children;
}
public synchronized void setChildren(Set<Children> children) {
this.children = children;
}
public void addChildren(Children child){
children.add(child);
}
}
Run Code Online (Sandbox Code Playgroud)
这是子对象,它包含"TestObj"的反向链接:
@Entity
@Table(name = "children")
public class Children {
public Children(){}
private Long id;
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
private TestObj testObj;
@ManyToOne
@JoinColumn
public TestObj getTestObj() {
return testObj;
}
public void setTestObj(TestObj testObj) {
this.testObj = testObj;
}
}
Run Code Online (Sandbox Code Playgroud)
我用这段代码坚持这个对象:
EntityManagerFactory entityManagerFactory = HibernateEntityMangerSingelton.getEntityManagerFactory();
EntityManager entityManager = entityManagerFactory.createEntityManager();
entityManager.getTransaction().begin();
TestObj user = new TestObj();
Children child = new Children();
user.addChildren(child);
try {
entityManager.persist(user);
entityManager.getTransaction().commit();
} catch (Exception e) {
System.out.println(e);
}finally{
entityManager.close();
}
Run Code Online (Sandbox Code Playgroud)
有人可以解释一下为什么会这样吗?
这很简单:你永远不会初始化testObj字段Children(应该命名为Child,BTW).Children.testObj是关联的所有者,并且是映射到连接列的字段,因此如果它为null,则连接列将为null.
| 归档时间: |
|
| 查看次数: |
10158 次 |
| 最近记录: |