簡體   English   中英

MongoDB 聚合 $match 雙嵌套 Object

[英]MongoDB Aggregation $match for double nested Object

我嘗試按日期查詢我的事件。 所以每個事件都有一個開始日期和一個結束日期。

這些事件所在的集合的結構如下:

 {
    "_id": "5f2a7feae0c4e10017308fe5",
    "events": [
        {
            "_id": "5f2a802ce0c4e10017308fe8",
            "end": {
                "dateTime": "2020-08-05T23:46:00.000Z"
            },
            "start": {
                "dateTime": "2020-08-05T22:46:00.000Z"
            }
        }, ...
    ]
}

所以我嘗試了以下聚合方法:

開始結束值是 ISO 字符串,在我的例子中是一年的開始和結束。

   Collection.aggregate([
    { $match: {owner: owner_id}},
    {$unwind: '$events'},
    {  $match : 
      { 'events.start.dateTime': 
        {$gte: start, 
        $lt: end
        }
      }
    }, 
    {$sort: {'events.start.dateTime': 1}}, 
    {$group: {_id: '$_id', 'events': {$push: '$events'}}}
])

當我嘗試使用$match過濾器時,我得到一個空數組。 但是,如果我在沒有$match過濾器的情況下嘗試它。 我從集合中獲取所有事件。

有人知道問題可能出在哪里嗎?

實際上 new Date('2020-06-17T10:03:46.000Z') 對我有用。

所以我的查詢如下所示:

Collection.aggregate([
    { $match: { $and: [ {owner: owner_id}, { 'events.start.dateTime': {"$gte": new Date(start), "$lt": new Date(end) } } ] } },
    {$unwind: '$events'}, 
    {$sort: {'events.start.dateTime': 1}}, 
    {$group: {_id: '$_id', 'events': {$push: '$events'}}}

暫無
暫無

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

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