当前位置:  开发笔记 > 编程语言 > 正文

Hibernate(JPA)如何做一个急切的查询,加载所有子对象

如何解决《Hibernate(JPA)如何做一个急切的查询,加载所有子对象》经验,为你挑选了2个好方法。

关于我之前的问题,我想确保加载所有子对象,因为我有一个可能需要访问数据的多个线程(从而避免延迟加载异常).我知道这样做的方法是在查询中使用"fetch"关键字(EJB QL).像这样:

select distinct o from Order o left join fetch o.orderLines

假设一个模型的Order类中包含一组OrderLines.

我的问题是,似乎需要"distinct"关键字,否则我似乎会Order为每个关键字取回一个OrderLine.我做对了吗?

也许更重要的是,有没有办法拉入所有儿童物品,无论多深?我们有大约10-15个类,对于服务器,我们将需要加载的所有东西......我正在避免使用,FetchType.EAGER因为这意味着它总是渴望,特别是Web前端加载一切 - 但也许这是要走的路 - 是你做什么?我似乎记得我们之前尝试过这个,然后得到非常慢的网页 - 但也许这意味着我们应该使用二级缓存?



1> 小智..:

更改注释是IMO的一个坏主意.因为它无法在运行时更改为惰性.最好让一切都变得懒惰,并根据需要进行获取.

没有映射,我不确定我理解你的问题.左连接提取应该是您描述的用例所需的全部内容.当然,如果订单行有一个订单作为其订单,您将获得每个订单行的订单.



2> Jeremy..:

我不确定在EJBQL中使用fetch关键字,可能会让它与注释混淆...

您是否尝试将FetchType属性添加到关系属性中?

@OneToMany(取= FetchType.EAGER)?

看到:

http://java.sun.com/javaee/5/docs/api/javax/persistence/FetchType.html http://www.jroller.com/eyallupu/entry/hibernate_exception_simultaneously_fetch_multiple


这家伙需要在运行时更改策略.
推荐阅读
Chloemw
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有