使用JPA和Hibernate时JOIN和JOIN FETCH有什么区别

使用JPA和Hibernate时JOIN和JOIN FETCH有什么区别,第1张

使用JPA和Hibernate时JOIN和JOIN FETCH有什么区别

在这两个查询中,你正在使用JOIN查询与至少一个部门关联的所有员工

但是,不同之处在于:在第一个查询中,你仅返回hibernate的Employes。在第二个查询中,你将返回员工和所有关联的部门。

因此,如果你使用第二个查询,则无需执行新查询即可再次命中数据库以查看每个员工的部门。

当你确定需要每个员工的部门时,可以使用第二个查询。如果不需要部门,请使用第一个查询。

如果你需要应用一些WHERe条件(你可能需要),我建议你阅读此链接:如何正确地将JPQL“ join fetch”和“ where”子句表示为JPA 2 CriteriaQuery?

更新资料

如果你不使用,

fetch
并且继续返回部门,那是因为你在雇员和部门(a
@OneToMany
)之间的映射设置为
FetchType.EAGER
。在这种情况下,任何带有
fetch
或不带有HQL的查询
FROM Employee
都会带到所有部门。请记住,默认情况下所有映射* ToOne(
@ManyToOne
@OneToOne
)均为EAGER。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5146609.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-17
下一篇 2022-11-18

发表评论

登录后才能评论

评论列表(0条)

保存