我有2个实体,它们之间是一对一的关系。 我正在使用Hibernate作为JPA提供程序。
在EntityA中,我有外键声明
public class EntityA{
.... //some properties
@OneToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "instructor_detail_id")
private EntityB entityB;
和EntityB看起来像
public class EntityB{
...//some properties
@OneToOne(mappedBy = "entityB",cascade = CascadeType.ALL)
private EntityA entityA;
我通过entityManger保留了新的 entityB 实例:
entityManager.getTransaction().begin();
EntityA ea = new EntityA ..//constructor with input arguments
EntityB eb = new EntityB ..//constructor with input arguments
eb.setEntityA(ea);
entityManager.persist(eb);
entityManager.getTransaction().commit();
我没有在entityA中获得外键列的id,这是实体表的数据库,该表填充了一个id,除了指向entryB的外键列之外,但是如果我保留EntityA的新实例,则全部效果很好
答案 0 :(得分:1)
由于在@OneToOne
和EntityA
中都有EntityB
映射。
您需要在两个实体中都设置@OneToOne
对象。
尝试这样的事情
public void saveData() {
EntityA a = new EntityA(...);
EntityB b = new EntityB(...);
a.setEntityB(b);
b.setEntityA(a);
entityManager.persist(a);
...
}
更多信息请参考here