java - Hibernate:使用 setFirstResult 和 setMaxResult 进行分页

标签 java hibernate pagination

我正在开发一个使用 Hibernate 作为 ORM 框架的 Java EE 项目。 为了对查询结果进行分页,我使用了 .setFirstResult 和 .setMaxResult 方法(Criteria API)。

问题是第一页显示正确,但当我转到第 2 页时,第一个结果显示与第一个页面的最后一个结果相同。

通过将日志记录级别切换为调试,我设法捕获了 Hibernate 构建的 SQL 查询。它们是:

-- First page query (results from 1 to 10)
select * from ( select this_.DT_FINE_VAL as DT1_5_0_, this_.DT_INI_VAL as DT2_5_0_, this_.CD_TIPO_PERIODO as CD3_5_0_, this_.DT_AGGIORNAMENTO as DT4_5_0_, this_.DT_INSERIMENTO as DT5_5_0_, this_.CD_USERID_AGG as CD6_5_0_, this_.CD_USERID_INS as CD7_5_0_ from GPER0_POVS2.T_POVS2_PERIODI_FUNZ this_ order by this_.CD_TIPO_PERIODO desc ) where rownum <= 10;

-- Second page query (results from 11 to 20)
select * from ( select row_.*, rownum rownum_ from ( select this_.DT_FINE_VAL as DT1_5_0_, this_.DT_INI_VAL as DT2_5_0_, this_.CD_TIPO_PERIODO as CD3_5_0_, this_.DT_AGGIORNAMENTO as DT4_5_0_, this_.DT_INSERIMENTO as DT5_5_0_, this_.CD_USERID_AGG as CD6_5_0_, this_.CD_USERID_INS as CD7_5_0_ from GPER0_POVS2.T_POVS2_PERIODI_FUNZ this_ order by this_.CD_TIPO_PERIODO desc ) row_ where rownum <= 20) where rownum_ > 10;

似乎第二个查询是“错误的”。 我正在使用 Oracle 作为 DBMS。 这可能是 Hibernate 错误吗?有人可以帮助我吗?

谢谢。

编辑: 这是代码:

Session currentSession = getCurrentSession();
Criteria criteria = currentSession.createCriteria(PeriodoFunz.class);
criteria.setResultTransformer(Criteria.ROOT_ENTITY);
Order order = paginationInfo.isAsc() ? Order.asc(paginationInfo.getOrderBy()) : Order.desc(paginationInfo.getOrderBy());
criteria.addOrder(order);
....
criteria = criteria.setFirstResult(paginationInfo.getFromRecord()).setMaxResults(paginationInfo.getPageSize());
List<PeriodoFunz> result = criteria.list();

最佳答案

您的顺序标准似乎导致 SQL 查询不稳定(以不同的查询顺序返回相同的结果行)。

您可以通过为唯一属性添加二阶标准来避免这种情况,例如编号:

Order order = paginationInfo.isAsc() ? Order.asc(paginationInfo.getOrderBy()) : Order.desc(paginationInfo.getOrderBy());
criteria.addOrder(order);
Order orderById = paginationInfo.isAsc() ? Order.asc("id") : Order.desc("id");
criteria.addOrder(orderById);

关于java - Hibernate:使用 setFirstResult 和 setMaxResult 进行分页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33396799/

相关文章:

php - 使用 "saved"搜索进行数据分页

java - Hibernate多对一属性在通过id持久化时为null

hibernate - Grails 3.2.1 WAR无法以缺少org.hibernate.boot.registry.selector.StrategyRegistrationProvider开头

java - Hibernate 唯一约束

javascript - JSON JavaScript 不起作用?

PHP 分页不适用于表格的第二页

python - 如何单击分页中的下一个按钮,其中下一个按钮没有类?

java - 如何验证通用 map 是否为空

java - 如何合并数组的内容?

java - 在java中生成随机双数的最快方法