Mon goose совокупный конвейерный поиск и вложенные объекты - PullRequest
1 голос
/ 03 апреля 2020

Я хотел бы поделиться с вами своей проблемой.

Итак, у меня есть 3 объекта, к которым необходимо получить доступ по моему запросу:

Оценка:

    [
        {
            _id: 1,
            questionary: 1,
            subject: 1
        },
        {
            _id: 1,
            questionary: 1,
            subject: 2
        },
    ] 

Пользователь

[
    {
        _id: 1
        name: "John Doe",
        photo: "photo1.jpg"
    },
        {
        _id: 2
        name: "Paul Smith",
        photo: "photo2.jpg"
    },
]

вопросник

[
    {
        _id: 1,
        title: "questionary 1",
        "date": "2020-02-08T00:00:00.000Z" 
    },
    {
        _id: 2,
        title: "questionary 2",
        "date": "2020-02-09T00:00:00.000Z" 
    }
]

Итак, моя цель - получить такие данные: список вопросников внутри него, список оценок, связанных с вопросником, а внутри оценки мне нужен объект пользователя. Например:

    [
        {
            "_id": "1",
            "title": "questionary 1",
            "evaluations": [
                {
                    "_id": "1",
                    "date": "2020-04-05T18:53:46.948Z"
                    "user": {
                        _id: 1,
                        "name": "John Doe",
                        "photo": "photo1.jpg"
                    }
                },
                {
                    "_id": "2",
                    "date": "2020-04-06T18:53:46.948Z",
                    "user": {
                        _id: 1,
                        "name": "John Doe",
                        "photo": "photo1.jpg"
                    }
                }
            ]
        }
    ]

Мой запрос:

return await Questionary.aggregate([{
      $lookup: {
        from: "evaluation", 
        localField: "_id",  
        foreignField: "questionary", 
        as: "evaluations",
      }
    },
    {
      $lookup: {
        from: "user",
        localField: "evaluations.user",
        foreignField: "_id",
        as: "user",
      }
    },
    { 
        $project: {
            _id: 1,
            title: 1,
            status: 1,
            evaluations: {
                _id: 1,
                date: 1,
                user: "$user"
            }
        },
    },
]);

И мой результат:

[
    {
        "_id": "1",
        "title": "questionary 1",
        "evaluations": [
            {
                "_id": "1",
                "date": "2020-04-05T18:53:46.948Z"
                "user": [
                    {
                        _id: 1,
                        "name": "John Doe",
                        "photo": "photo1.jpg"
                    },
                    {
                        _id: 2,
                        "name": "Paul Smith",
                        "photo": "photo2.jpg"
                    }
                ]
            },
            {
                "_id": "2",
                "date": "2020-04-06T18:53:46.948Z",
                "user": [
                    {
                        _id: 1,
                        "name": "John Doe",
                        "photo": "photo1.jpg"
                    },
                    {
                        _id: 2,
                        "name": "Paul Smith",
                        "photo": "photo2.jpg"
                    }
                ] 
            }
        ]
    }
]

Пользователи моих оценок объединяются, но это не то, что я хочу, я просто хочу внутреннюю информацию пользователя внутри оценки.

Любое предложение?

1 Ответ

0 голосов
/ 04 апреля 2020

Вы должны иметь возможность использовать вложенные $lookup, используя некоррелированные подзапросы, как описано в https://docs.mongodb.com/manual/reference/operator/aggregation/lookup/#join -условиях-и-некоррелированных подзапросах

В вашем случай, который будет:

return await Questionary.aggregate([{
      $lookup: {
        from: "evaluation",
        let: {questId: "$_id"},
        pipeline: [{
          $match: {
            $expr: {
              $eq: ["$$questId", "$questionary"]
            }
          },
        }, {
          $lookup: {
            from: "user",
            localField: "subject",
            foreignField: "_id",
            as: "user",
          }
        }],
        as: "evaluations"
      }
    }
]);
...