gpt4 book ai didi

jpa-2.0 - 使用 JPA 加载懒惰 vs 急切加载

转载 作者:行者123 更新时间:2023-12-05 00:34:55 25 4
gpt4 key购买 nike

我正在尝试让一些 JPA 的东西起作用。我有一个表,它有另一个表的外键。当我生成 JPA 实体时,我会在这些变量上获得一对多的注释……我还需要做什么才能将所有表恢复到结果集中?如果我真的这样称呼它。这是我正在尝试做的一个例子。

@OneToMany(mappedBy="resourceId")
private List<DistributionLink> distributionLinkCollection;

@OneToMany 注释很漂亮......

我正在考虑取回所有值,我只需要调用调用此表的命名查询,对吗?
qLaunchArr = (QuickLaunch[])emf.createNamedQuery("QuickLaunch.getQuickLaunch").getResultList().toArray();

我是否认为我还将获得一组包含所有结果集的 DistributionLinks?
现在我知道这与 Eager Loading 与 Lazy loading 有关。究竟是什么,我不确定。我知道延迟加载只加载显式调用的 @oneToMany 属性(我认为)?我怎样才能取回我需要的所有收藏品。我是否需要遍历结果集并调用命名查询以使用命名查询获取所有结果集?

谢谢。

最佳答案

当您根据是否仍在事务上下文中选择延迟加载某些内容时,当您使用 getter 获取子集合时,JPA 应该自动为您获取它。因此,如果数据离开具有获取父对象的实体管理器的 session bean,您将无法自动实例化延迟加载的集合。

如果您选择使用 EAGER 获取策略,则该集合的每个实例都将被预先实例化,并且可以在任何地方使用。

一个很好的折衷方案,可以让您避免限制您的设计决策(但仍然允许您利用延迟加载来避免在每次获取这些记录时加载您不需要的内容)只在获取这些记录的 bean 中处理这些集合父实体会在您提前知道您需要该集合时,坚持您的查询:

JOIN FETCH distributionLinks

关于jpa-2.0 - 使用 JPA 加载懒惰 vs 急切加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10128356/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com