Jpa 分页,带有数字和下一个、上一个

问题描述 投票:0回答:4

如果有人已经问过这个问题,我很抱歉问这个问题,并且问了一个可能很愚蠢的问题,但我对此很陌生,你们是专家,我很乐意从你们的专家建议和经验中学习。

我想向每页显示 200 条记录的应用程序添加分页。 页面底部应该有数字。 如果有1050,则首页显示100,页面底部显示数字1,2,3,4,5 & 6。

完成此任务的一般逻辑是什么? 我知道数据库每次都必须选择 200,并且我必须跟踪第一条记录。

  1. 有没有办法知道总共会返回多少条记录,以便我知道页面底部要显示多少个数字? 是否需要选择 count() 语句或其他语句?
  2. 对于 1050 条记录,将显示数字 1、2、3、4、5 和 6,单击每一个都需要调用服务器。 有没有办法知道下次调用服务器时将返回多少条记录?是否需要选择 count() 语句或其他语句?
java spring hibernate jpa pagination
4个回答
8
投票

您可以使用 JPA Criteria API 来完成此操作。假设 TypedQuery,您将使用

setFirstResult
setLastResult
来限制从数据库返回的记录。当然,这些方法的值将取决于请求的页面以及每页显示的记录数。

first = (page - 1) * page size;
last = (page * size) - 1;

注意:假设第一页为 1(而不是零)。

要获取记录计数,请执行标准条件查询。举个例子:

final CriteriaBuilder builder = entityManager.getCriteriaBuilder();
final CriteriaQuery<Long> countQuery = builder.createQuery(Long.class);
countQuery.select(builder.count(countQuery.from(MyEntity.class)));
final Long count = entityManager.createQuery(countQuery)
        .getSingleResult();

您也可以自定义上述代码来执行相对于另一个查询的计数。最后,您需要某种方式将总计数返回给客户端。实现此目的的一种方法是将查询的结果集包装在另一个包含计数属性的对象中,或者将所述对象作为 DAO 调用的结果返回。或者,您可以将计数属性存储在请求范围内的对象中。

public class ResultListWrapper<T> {
    private Long count;
    private Collection<T> results;

    // constructor, getters, setters
}

2
投票

您通常会执行相同的查询,除了在运行实际查询之前使用 count int 选择列表而不是列来查找有多少页。 然后可以通过以下方式在休眠中获取特定页面:

int maxRecords = // page size ...
int startRow = // page number * page size
Query query = session.createQuery('...');
query.setMaxResults(maxRecords);
query.setFirstResult(startRow);

如果执行额外查询的操作成本太高,那么您可以考虑仅提供下一个/上一个链接,或者根据需要通过 ajax 提供额外页面(例如,当最后一个加载的数据进入视图时)。

为了显示分页结果,包括显示页码链接,我建议(假设您使用 jsp 页面来显示此数据)使用 display tag JSP 标签库。 显示标签处理表格数据的分页和排序显示,假设您可以将其获取到 JSP。


0
投票

是的,您必须在获取行本身之前进行选择计数。


0
投票

看看Spring Data JPA。它基本上是按照 Perception 之前建议的方式工作的,只是你不必这样做,框架会为你做这件事。默认情况下您会进行分页和排序(如果您不想使用Query DSL,您仍然需要自己进行过滤)。

他们的主页上有一个 1 小时的视频,展示了快速介绍,但您只需要观看大约 15 分钟即可了解 id 的用途。

© www.soinside.com 2019 - 2024. All rights reserved.