问题描述
我正在尝试构建一个谓词,在该谓词中,我将基于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());
}