1

我需要编写一个查询来返回按创建日期排序的用户。查询必须接受offsetand count,所以我需要从offset结尾处获取所有行offset + count。我可以轻松编写相应的 SQL 查询,但无法将其转换为 HQL。

更清楚地说,相应的 SQL 如下所示:

SELECT * FROM users
ORDER BY created_at
OFFSET 20 ROWS
FETCH FIRST 10 ROW ONLY;

问:如何在 HQL (JP-QL) 中实现相同的功能?

我将 Hibernate 与 Quarkus 和 Panache 一起使用。

4

1 回答 1

1

假设您有以下实体:

@Entity
@Table(name = "users")
public class User
{
   // ...
   @Column(name = "created_at")
   private LocalDate createdAt;
}

您可以编写以下查询:

List<User> users = entityManager.createQuery(
   "select u from User u order by u.createdAt", User.class)
.setFirstResult( 10 )
.setMaxResults( 2 )
.getResultList();

Hibernate 将生成以下 sql:

select
    u.id as id1_3_,
    -- ...
    u.created_at as created_at_8_3_
from
    users u
order by
    u.created_at asc
limit ?
offset ?
于 2021-02-12T14:52:33.680 回答