我正在使用 Spring Repository 的自定义查询。我可以创建这样的自定义方法:
List<Order> findTop1ByOrderByCreateDateTimeDesc();
获取最新订单。
但是如何获取按 CreateDateTime 排序的特定订单的上一个和下一个订单?
最佳答案
以下两个 JPQL 查询将返回与指定最接近的 createDateTime 的订单。
上一个订单:
select o from Order o where o.createDateTime = (select max(prev.createDateTime) from Order prev where prev.createDateTime < :specificOrderCreateDateTime)
下一个订单:
select o from Order o where o.createDateTime = (select min(next.createDateTime) from Order next where next.createDateTime > :specificOrderCreateDateTime)
关于java - 如何使用 Spring JPA 检索某个记录器之前和之后的记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59040420/