假设有两个具有ManyToOne关系的实体:
@Entity
public class A {
private long code;
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
public long getCode() {
return code;
}
public viod setCode(long code) {
this.code = code;
}
// additional setters and getters
}
@Entity
public class B {
private long code;
private A a;
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
public long getCode() {
return code;
}
public viod setCode(long code) {
this.code = code;
}
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="acode", nullable=false)
public A getA() {
return a;
}
public void setA(A a) {
this.a = a
}
// additional setters and getters
}
作为业务流程的一部分,我有现有A对象的代码值,我需要插入新的B对象并将其与现有的A相关联。 这段代码工作正常:
// inject em
A a = em.find(A.class, code);
B b = new B();
b.setA(a);
em.persist(b);
我的问题是“A a = em.find(A.class,code)”行。这看起来像是一个冗余查询,因为B表包含一个外键(acode)。 为了提高性能,我尝试使用现有代码值创建一个对象:
A a = new A();
a.setCode(code);
B b = new B();
b.setA(a);
em.persist(b);
但它不起作用。 有没有办法避免不必要的查询?
答案 0 :(得分:5)
在这种情况下,可以使用特殊的getReference()
方法代替find()
。它创建一个具有指定id的代理对象,而不发出queires。保存A
时,数据库端的外键约束会检查具有该ID的B
是否存在。
A a = em.getReference(A.class, code);
B b = new B();
b.setA(a);
em.persist(b);