使用 Hibernate 在 JPA 中分页本机 SQL 查询没有错误

Eph*_*ras 3 java hibernate jpa nativequery

感谢您的关注,对不起我英语 :S

我正在使用 JPA 2.0 和 Hibernate 4.X 来执行一些 sql 本机查询。代码很简单:

private void doIt() throws Exception {
        EntityManager em = getEntityManager();
        Query q = em.createNativeQuery("A very simple native query, which return no entities, but collections of arrays");
        q.setFirstResult(0);
        q.setMaxResults(5);
        Collection<Object> results = q.getResultList();
        System.out.println("1"); //Means page 1
        for (Object elem : results) {
            String line = "";
            Object[] row = (Object[]) elem;
            for (Object object : row) {
                if(object==null){
                    object="null";
                }
                line += object +"("+object.getClass()+")"+ ",";
            }
            System.out.println(row.length + " " + line);

        }


        em = getEntityManager();
        q = em.createNativeQuery("The same simple native query, which return no entities, but collections of arrays");
        q.setFirstResult(5);
        q.setMaxResults(5);
        results = q.getResultList();
        System.out.println("2"); //Means page 2
       for (Object elem : results) {
            String line = "";
            Object[] row = (Object[]) elem;
            for (Object object : row) {
                if(object==null){
                    object="null";
                }
                line += object +"("+object.getClass()+")"+ ",";
            }
            System.out.println(row.length + " " + line);

        }


        em = getEntityManager();
        q = em.createNativeQuery("The same simple native query, which return no entities, but collections of arrays");
        q.setFirstResult(10);
        q.setMaxResults(5);
        results = q.getResultList();
        System.out.println("3"); //Means page 3
        for (Object elem : results) {
            String line = "";
            Object[] row = (Object[]) elem;
            for (Object object : row) {
                if(object==null){
                    object="null";
                }
                line += object +"("+object.getClass()+")"+ ",";
            }
            System.out.println(row.length + " " + line);

        }
    }
Run Code Online (Sandbox Code Playgroud)

我的结果是这样的:

1 
data1,data2,...,data-n        -->I need this output
data1,data2,...,data-n
data1,data2,...,data-n
data1,data2,...,data-n
data1,data2,...,data-n

2
data1,data2,...,data-n,6      -->OMG! lol
data1,data2,...,data-n,7
data1,data2,...,data-n,8
data1,data2,...,data-n,9
data1,data2,...,data-n,10

3
data1,data2,...,data-n,11
data1,data2,...,data-n,12
data1,data2,...,data-n,13
data1,data2,...,data-n,14
data1,data2,...,data-n,15
Run Code Online (Sandbox Code Playgroud)

简而言之,第一页的输出每行有n个项目(这是我想要的输出),但第二页和第三页有n+1个项目,而附加的项目似乎是已带来的行数。

有人有同样的事情发生吗?我在 Hibernate 的文档中搜索过,但我无法解决这个“有趣的:@”问题。

这段代码是用Toplink 执行的,没有问题。

非常感谢!!:)

Pio*_*sen 5

这是在 Hibernate 中完成分页的方式——使用它的Dialect实现。Dialect 的 API 如下:它需要 SQL 查询被分页和范围信息,并生成 SQL 语句产生所需的行范围。

在 case 或 Oracle Dialect 中,它可以使用ROWNUM并且不需要修改您的原始查询。在例如 DB2 或SQL Server的情况下,方言需要显着改变您的查询(包括但不限于在输出中添加额外的列),以便能够为您过滤所需的范围。

最后一件事——为什么你的第一页或结果是不同的。SQL 允许(取决于实现)构造像SELECT TOP n,因此范围[0, n]和的查询[m, n]通常是不同的。