【问题标题】:Is it possible using JPA to stream results from javax.persistence.Query.getResultList()?是否可以使用 JPA 从 javax.persistence.Query.getResultList() 流式传输结果?
【发布时间】:2011-01-20 06:21:06
【问题描述】:
我是 JPA 的新手,我想知道是否可以从结果集中流式传输数据,我的意思是我不想等待执行查询以开始处理第一个结果,例如在批量的情况下。
是否有可能使用 JPA API 或任何社区采用的解决方法?最终使用 JPA 实现的功能?
【问题讨论】:
标签:
hibernate
jpa
scrollableresults
【解决方案1】:
出于显而易见的原因,“主”选择必须在对结果集进行任何操作之前完成。我不确定您要在这里实现什么...也许您需要使某些字段变得惰性,以便更快地获得第一个结果并在处理它们时获取详细信息?
【解决方案2】:
使用@javax.persistence.PostLoad 注解对您来说可行吗?通过这种方式,您可以将操作与从数据存储创建给定对象的那一刻联系起来。我不确定这是否正是您要寻找的。p>
【解决方案3】:
你可以在 JPA 上使用真正的流:
public interface UserRepository extends JpaRepository<User, Integer> {
// ...
Stream<User> findAllByName(String name);
// ...
}
您可以在this nice article 中找到更多示例。
【解决方案4】:
现在javax.persistence.TypedQuery 现在有getResultStream() 流数据的方法,但是默认实现仅将getResultList() 包装到流中(因此,无论如何它会将所有数据加载到内存中)。但是 Hibernate 用真正的流媒体覆盖了这种行为。