gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-11-01 02:40:55 26 4
gpt4 key购买 nike

我正在开发一个使用 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com