背景:系統中需要通過起始時間、結束時間來查詢數據
1、原寫法
if(StringUtil.isNotEmpty(startTime) && StringUtil.isNotEmpty(endTime)){
criteria.and("create_time").gte(startTime);
criteria.and("create_time").lte(endTime);
}
2、運行報錯
org.springframework.data.mongodb.InvalidMongoDbApiUsageException: Due to limitations of the com.mongodb.BasicDocument, you can't add a second 'create_time' expression specified as 'create_time : Document{{$lte=2020-07-31 00:00:00}}'.
Criteria already contains 'create_time : Document{{$gte=2020-07-01 00:00:00}}'
原因:Criteria不允許一個字段出現多次
3、修改后
if(StringUtil.isNotEmpty(startTime) && StringUtil.isNotEmpty(endTime)){
criteria.and("create_time").gte(startTime).lte(endTime);
}