MongoDB $lookup和$group返回空数组



我正在尝试使用以下聚合:

[
{$unwind: '$names'},
{$sort: {'names.changed_at': -1}},
{$group: {_id: '$_id', names: {$push: {value: '$names.value', changed_at: '$names.changed_at'}}}},
{$limit: 3},
{
$lookup: {
from: 'users',
localField: 'id',
foreignField: 'id',
as: 'user',
},
},
{$unwind: '$user'},
{
$project: {
_id: 0,
old_name: {$first: '$names'},
user: {avatar_url: 1, current_tag: 1},
},
}
]

使用$lookup和$group返回[]。当我删除$lookup或$group时,它会工作并给出预期的结果。

如何解决这个问题?

您试图将id字段用于$lookup,但在此$group阶段之后:

{ $group: { _id: '$_id', names: { $push: { value: '$names.value', changed_at: '$names.changed_at' } } } },

文档结构为:

{
_id: ObjectId,
names: { value: string, changed_at: Date }[]
}

可以看到,没有id字段。

如果这是一个错别字,只需将id更改为_id。如果这不是一个错别字,那么你需要"保存"。$group阶段的id字段,如下:

{
$group: {
_id: '$_id',
names: {$push: {value: '$names.value', changed_at: '$names.changed_at'}},
id: {$first: "$id"}
}
}

最新更新