1

我正在使用 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 获取?

4

1 回答 1

1

正如在问题中所说,并且也记录在这里fetch使用内部连接。

使用重载 fetch 方法时可以指定连接类型,该方法也将JoinType作为参数:

dev.fetch(Devices_.devInterfaces, JoinType.LEFT)
于 2013-08-18T18:09:41.050 回答