栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

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

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用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。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/441890.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号