簡體   English   中英

使用 facet 時的 Mongodb 排序問題

[英]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 個頂級字段_iderrorCount的文檔。

在執行{$sort: {"date": -1}}時,頂層沒有date字段,因此排序沒有效果。

解決方案:要么使用{$sort: {"_id.date": -1}}要么使用投影,在排序之前將嵌入在_id中的字段移動到頂層。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM