#javascript #node.js #database #mongodb #mongoose
Вопрос:
Я пытаюсь использовать следующую агрегацию:
[
{$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, это работает и дает ожидаемый результат.
Как мне это исправить?
Ответ №1:
Вы пытаетесь использовать 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
. если это не опечатка, то вам нужно «сохранить» id
поле на $group
этапе, вот так:
{
$group: {
_id: '$_id',
names: {$push: {value: '$names.value', changed_at: '$names.changed_at'}},
id: {$first: "$id"}
}
}
Комментарии:
1. Это была не опечатка ^^ Я ценю вашу помощь!