微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在 Hibernate 中获取具有偏移量和计数的行?

如何解决如何在 Hibernate 中获取具有偏移量和计数的行?

我需要编写一个查询,返回按创建日期排序的用户查询必须接受 offsetcount,因此我需要获取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 ?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。