首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >带分页的Spring数据Oracle JPA性能

带分页的Spring数据Oracle JPA性能
EN

Stack Overflow用户
提问于 2017-06-29 20:01:36
回答 1查看 3K关注 0票数 1

我希望检索具有JpaRepository的大型数据集,该数据集由Oracle表支持。这些选择是返回实体的集合(List)或Page,然后逐步遍历结果。请注意-我必须消耗这一组的每一张唱片,准确地说是一次。这不是一个"look-for-the-first-one-from-a-large-dataset-and-return“操作。

虽然分页的想法很吸引人,但是性能将是可怕的(n^2),因为对于每个被查询的页面,oracle将不得不提取之前的n-1页,随着我在结果集中的深入,性能会越来越差。

我对List备选方案的理解是,整个结果集将加载到内存中。对于oracle,spring没有支持结果集。

下面是我的问题

  1. 我对List如何处理Spring数据的理解是正确的吗?如果不是,我将只使用List
  2. 如果我是正确的,是否有其他方法可以流Oracle/JPA结果集?
  3. 还有第三条路我不知道。
EN

回答 1

Stack Overflow用户

发布于 2017-06-30 10:07:47

SDJ中的可分页方法调用每个请求的附加select count(*) from ...。我认为这就是问题的原因。为了避免这种情况,您可以使用Slice而不是Page作为返回参数,例如:

代码语言:javascript
运行
复制
Slice<User> getAllBy(Pageable pageable);

或者您甚至可以使用带有分页的实体的List

代码语言:javascript
运行
复制
List<User> getAllBy(Pageable pageable);

附加信息

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44833982

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档