[英]Mongodb sorting issue when using facet
使用 facet 和 mongo 聚合時,mongodb 排序不起作用。 使用 function 排序后,結果未排序。 我正在將 utc 日期 fromat 轉換為日期字符串。
還需要刪除每個文檔的_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
階段將返回只有 2 個頂級字段_id
和errorCount
的文檔。
在執行{$sort: {"date": -1}}
時,頂層沒有date
字段,因此排序沒有效果。
解決方案:要么使用{$sort: {"_id.date": -1}}
要么使用投影,在排序之前將嵌入在_id
中的字段移動到頂層。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.