MongoDB $lookup и $group возвращает пустой массив

#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. Это была не опечатка ^^ Я ценю вашу помощь!