- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在开发一个使用 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/
我有一个类,它返回查询中的所有实体,受最大值和最小值限制: @SuppressWarnings("unchecked") public static List getAll(Class klass,
我是 hibernate 新手。我对标准的 setFirstResult 方法感到困惑。从文档看来,hibernate 从给定的数字返回行。 由于 SQL 查询不保证没有 order by 子句的行的
我正在使用 nHibernate 并尝试实现一些分页。如果我运行这段代码 IList list = session.CreateQuery("FROM Author").List(); 它返回 8 条
我的应用程序中有分页问题。我想使用 setFirstResult 和 setMaxResults 方法,但它给了我错误的输出: (我的数据库:SQLite) 例子: Session sessi
什么会导致 CriteriaQuery orderBy 方法停止工作? 实现如下: OpenJPAEntityManager kem = OpenJPAPersistence.cast(ent
JPA setFirstResult() 和 setMaxResults() 方法是否进行真正的分页?我的意思是从数据库的角度来看?还是不? 例如,如果查询返回 1000000 行,并且我使用这些方法
什么会导致 CriteriaQuery orderBy 方法停止工作? 实现如下: OpenJPAEntityManager kem = OpenJPAPersistence.cast(ent
我的数据库中有 10000 条记录,我想第一次获取 100 条记录,第二次获取 100 条记录,依此类推。我正在使用 setFirstResult() 和 maxResult()。我正在维护一个计数器
我使用 ORM 框架已有一段时间了,但我对 Hibernate 还是比较陌生。 假设您有一个查询(它是一个查询还是一个条件,无关紧要)检索了一个很好的结果集并且您想要对其进行分页。您更愿意使用 set
我有以下有效方法: public List filterOn(String course, String university, List providers, String sortOn, int
我正在开发一个使用 Hibernate 作为 ORM 框架的 Java EE 项目。为了对查询结果进行分页,我使用了 .setFirstResult 和 .setMaxResult 方法(Criter
当我使用 SetFirstResult 和 SetMaxResult 时,如果查询已连接,则结果具有重复结果而不是唯一结果。 然后我将所有类型的 Distinct 助手用于标准 api。但它不会过滤整
我正在尝试使用 setFirstResult() 和 setMaxResults() 对 Hibernate 进行分页,但是当将第一个结果设置为 0 时我没有得到预期的结果. 执行以下操作时: Que
有没有办法从已经构建的 DetachedCriteria 中删除/撤消 .SetMaxResults()/.SetFirstResults()? 不改变原来的DetachedCriteria就可以做到
这个查询: $this->getEntityManager() ->createQuery("SELECT k FROM FooBarBundle:Kode k WHERE k.kod
我是一名优秀的程序员,十分优秀!