6

我有两个实体类在 @OneToOne 关系中。示例代码如下:

public class A {
@Id
private int id;
private String name;
@JoinColumn(name = "B_ID", referencedColumnName = "id")
@OneToOne(cascade=CascadeType.ALL)
private B b;

//setters and getters

}

public class B {
@Id
private int id;
private String name;
@OneToOne(mappedBy="b")
    private A a;
//setter and getters

}

我的问题是“我可以在 B 类中使用 setA(A a) 方法吗?我的意思是这样......

em.getTransaction().begin();
A aa = new A();
aa.setId(1);
aa.setName("JJ");
em.persist(aa);

B bb = new B();
bb.setId(1);
bb.setName("CC");
bb.setA(aa);
em.persist(bb);
em.getTransaction().commit();

当我这样尝试时,表A(B_ID)中的foreign_key字段被保存为null。
请帮我。

4

3 回答 3

12

在这里,您已经mappedBy在上面指定了 B 类private A a;。在双向关系中,mappedBy意味着我不是所有者。所以这意味着A是关系的所有者。

在 A 表中,您将拥有 B 表的外键。由于 A 是所有者,因此 A 假设将操作级联到 B。理想情况下,您应该尝试a.setB()然后持久化 a。

试试下面:

em.getTransaction().begin();
//first create B.
B bb = new B();
bb.setId(1);
bb.setName("CC");
em.persist(bb);

//create A with B set in it.
A aa = new A();
aa.setId(1);
aa.setName("JJ");
aa.setB(bb);
em.persist(aa);
em.getTransaction().commit();

或者

em.getTransaction().begin();
//first create B.
B bb = new B();
bb.setId(1);
bb.setName("CC");
// no need to persist bb.

//create A with B set in it.
A aa = new A();
aa.setId(1);
aa.setName("JJ");
aa.setB(bb);
em.persist(aa); // because of cascade all , when you persist A ,
// B will also be persisted.
em.getTransaction().commit();
于 2013-02-07T08:07:37.710 回答
1

使用 @Cascade({CascadeType.SAVE_UPDATE}) 级联更改

public class B {
@Id
private int id;
private String name;
@OneToOne(mappedBy="b")
 @Cascade({CascadeType.SAVE_UPDATE}) 
    private A a;
//setter and getters

}
于 2013-02-07T18:52:08.800 回答
0

您需要在 em.persist(bb) 之前添加 aa.setB(bb)

em.getTransaction().begin();
A aa = new A();
aa.setId(1);
aa.setName("JJ");
em.persist(aa);

B bb = new B();
bb.setId(1);
bb.setName("CC");

aa.setB(bb);//this line should be added
bb.setA(aa);

em.persist(bb);
em.getTransaction().commit();
于 2017-04-08T05:56:26.733 回答