[英]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.