我正在使用 Hibernate 4 作为我的提供者使用 JPA 2 CriteriaBuilder 构建查询。我一直在玩 FetchModes,并得出结论 SELECT 是我需要的。但是 SELECT 强制启用 FetchType.LAZY。我在某处读过这个,似乎就是这样。
在 Devices 类中,此配置会产生正确的结果:
@Fetch(value=FetchMode.SELECT)
@OneToMany(fetch=FetchType.EAGER, mappedBy = "device")
public List<DevInterfaces> getDevInterfaces() {
return this.devInterfaces;
}
但是我不希望 FetchType=EAGER 在我的实体中硬编码。我想控制提取发生的时间,我想我可以用这样的 fetch() 来做到这一点:
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Devices> dq = cb.createQuery(Devices.class);
Root<Devices> dev = dq.from(Devices.class);
dev.fetch(Devices_.devInterfaces)
但结果是内部连接,我不希望这样。
如何在不硬编码 FetchType.EAGER 的情况下使用 FetchMode.SELECT 获取?