Ранее у меня был ниже упомянутый конвейер агрегации.
db.EXCEPTIONS.aggregate(
[{ $match : {
$and : [
{workflow_stage_current_assignee : {$ne:null}},
{CreatedDate:{$gt:ISODate("2017-07-12")}},
{CreatedDate:{$lt:ISODate("2018-07-12")}}
]}
},
{
$group : {_id: {user : "$workflow_stage_current_assignee", cm:"$control_monitor"},
exceptions:{$sum:1} }
},
{ $project : {"user":1,"cm":1,"exceptions":1}},
{ $sort : {"exceptions":1}}
]);
И соответствующее преобразование в шаблоне Mongo показано ниже.
Calendar fromDate = Calendar.getInstance();
fromDate.set(2016, 7, 12, 0, 0, 0);
Calendar toDate = Calendar.getInstance();
toDate.set(2018, 7, 12, 23, 59, 59);
MatchOperation match = Aggregation.match(new Criteria("workflow_stage_current_assignee").ne(null)
.andOperator(new Criteria("CreatedDate").gte(new Date(fromDate.getTimeInMillis()))
.andOperator(new Criteria("CreatedDate").lte(new Date(toDate.getTimeInMillis())))));
GroupOperation group = Aggregation.group("workflow_stage_current_assignee","control_monitor").count().as("exceptions");
ProjectionOperation project = Aggregation.project("workflow_stage_current_assignee","control_monitor","exceptions");
SortOperation sort=Aggregation.sort(Sort.Direction.DESC,"exceptions");
Aggregation aggregation = Aggregation.newAggregation(match,group,project,sort);
AggregationResults<ExceptionCount> output = mongoTemplate.aggregate(aggregation, "EXCEPTIONS", ExceptionCount.class);
Это сработало нормально. Затем я изменил исходный запрос, как показано ниже, и добавил дополнительную опцию группировки как просроченную.
$group : {_id: {user : "$workflow_stage_current_assignee", cm:"$control_monitor"},
exceptions:{$sum:1},
},
overdue: {$sum : {$cond :[
{$gt:["$CreatedDate",ISODate("2017-07-12")]},1,0
]}
}
Но я не знаю, как добиться этого дополнительного группового предложения в запросах шаблона Mongo. Я искал в Интернете, но большинство результатов используют DBObject из старого API. Может ли кто-нибудь помочь мне в этом с шаблоном Mongo?