如何使用谓词构建器返回“今日订单”

问题描述

我正在尝试构建一个谓词,在该谓词中,我将基于orderType返回订单列表-例如TodaysOrders,AllOrders,PendingOrders,FailedOrders等。

对于TodaysOrders,我只想返回具有今天日期的订单,而不是过去24小时内的预订。

我尝试了以下代码段,这将返回过去的24小时。

if(orderType == todaysOrders){ 谓词= builder.greaterThanorEqualTo(root.get(RECEIVED_DATE), LocalDateTime.Now()。minusDays(1));

我尝试了以下代码段,由于没有其他时间戳记为LocalDateTime.Now()的代码,因此返回0的结果

if(orderType == todaysOrders){ 谓词= builder.equal(root.get(RECEIVED_DATE), LocalDateTime.Now();

有人知道我可以做到这一点吗?

RECEIEVED_DATE是ordersRepository中的一列,类型为LocalDateTime。

解决方法

您必须使用LocalDate而不是LocalDateTime,然后调用

if (orderType == todaysOrders) {
    predicate = builder.greaterThanOrEqualTo(root.get(RECEIVED_DATE),LocalDate.now().atStartOfDay());
}