使用facet时Mongodb排序问题



mongodb排序在使用facet和mongo聚合时不起作用。结果不在使用的排序函数之后进行排序。我正在将utc日期从at转换为日期字符串。

还需要删除每个文档的_id

请帮我查询

输入使用的json有效载荷

{
"_id": {
"$oid": "122434543sdf"
},
"eventName": "ev1",
"channelId": "channel1",
"domain": "domain1",
"lob": "lob1",
"eventCategory": "category1",
"producerCSI": "1234",
"topicName": "topic1",
"dateTime": "2021-12-29T20:04:37Z",
"errorDetailsList": [{
"errorType": "Missing data",
"count": {
"$numberLong": "1"
}
}, {
"errorType": "Invalid Data",
"count": {
"$numberLong": "1"
}
}]
}
]
}

Mongo查询我已经写了


db.failureevents.aggregate( [
{$unwind: { "path": "$errorDetailsList", "preserveNullAndEmptyArrays": true} },
{$addFields: {errorType: {$arrayElemAt: [{$objectToArray: "$errorDetailsList"}, 0]}}},
{$addFields: {"errorType": "$errorType.v"}},
{$lookup : { "from": "errordescription", "localField": "errorType", "foreignField": "errorType", "as": "dataset" }},
{$unwind: { "path": "$dataset", "preserveNullAndEmptyArrays": true } },
{$facet: {
"top": [
{ "$group": {
"_id": {
"lob": "$lob",
"channel": "$channelId",
"domain": "$domain",
"eventCategory": "$eventCategory",
"prodcuerCSI": "$producerCSI",
"topicName": "$topicName",
"eventName": "$eventName",
"errorType":"$dataset.errorType",
"errorMessage":"$dataset.errorMessage",
"dateTime":"$dateTime",
"date" : { "$dateFromString" : { "dateString" : "$dateTime"} },
},
"errorCount": {"$sum" : "$errorDetailsList.count"},
}
}],
"rest": [ {$count: 'count'}]
}},
{ "$project": { "_id" : 0,"data": { "$concatArrays": ["$top", "$rest"] }}},
{ "$unwind": "$data" },
{ "$replaceRoot": { "newRoot": "$data" }},
{$sort: {"date" : -1}},
{ $skip: 0 },
{ $limit: 100},
]);

MongoDB聚合中的$group阶段只保留组规范中的那些字段。

在您的示例管道中,top部分中的$group阶段将返回只有两个顶级字段_iderrorCount的文档。

在执行{$sort: {"date" : -1}}时,顶层没有date字段,因此排序没有效果。

解决方案:使用{$sort: {"_id.date" : -1}}或使用投影,在排序之前将嵌入_id中的字段移动到顶层。

最新更新