如何在 Hibernate 中获取具有偏移量和计数的行?
How to fetsch rows with offset and count in Hibernate?
我需要编写一个查询,让 return 用户按创建日期排序。查询必须接受 offset
和 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 一起使用。
假设您有以下实体:
@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 ?
我需要编写一个查询,让 return 用户按创建日期排序。查询必须接受 offset
和 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 一起使用。
假设您有以下实体:
@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 ?