ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java – Hibernate分页机制

2019-09-30 16:05:15  阅读:194  来源: 互联网

标签:java orm jpa hibernate pagination


我试图使用Hibernate分页查询(PostgreSQL)

我为我的sql查询设置了setFirstResult(0),setMaxResults(20).我的代码如下:

Session session = getSessionFactory().getCurrentSession();
session.beginTransaction();
Query query = session.createQuery("FROM Customers");
query.setFirstResult(0);
query.setMaxResults(20);
List<T> entities = query.list();
session.getTransaction().commit();

但是在查看SQL hibernate日志时,我仍然看到完整的SQL查询:

Hibernate: select customer0_.id as id9_, customer0_.customer_name as dst2_9_, customer0_.addres as dst3_9_ from tbl_customers customer0_  

为什么查询Hibernate分页SQL日志时没有LIMIT OFFSET?

有谁知道Hibernate分页机制?

我想Hibernate将选择所有数据,将数据放入Resultset,然后在Resultset中进行分页,对吧?

解决方法:

我在查询和休眠回调中使用.两者都按预期工作. Hibernate Query在给定的First和Max大小之间执行结果.这里好像你通过SQL而不是HQL来查询.如果是的话它应该不起作用.

– 在这里查看我的代码.

        Query query = this.getSession().createQuery("FROM QueryType");
        query.setFirstResult(0);
        query.setMaxResults(20);
        List toDelete = query.list();

并在日志中:

选择
        *
    从
        ( 选择
             – 所有列名称. (不想在这里分享.)
        从
            MY_TBL_NAME querytype0_)
    哪里
        rownum< =?

标签:java,orm,jpa,hibernate,pagination
来源: https://codeday.me/bug/20190930/1836046.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有