使用Mongoose在两个级别上填充

时间:2018-02-08 17:52:58

标签: javascript node.js mongoose

我正在制作一个电影网站来开发我的MEAN-stack技能。目前我正在尝试从我的数据库中获取电影文档。该电影文档具有属性评论,其是ObjectId的数组,其引用了Review模型。我填充了这些Object Ids,每个Review文档都有以下结构:

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var schema = new Schema({
    user: {type: Schema.Types.ObjectId, ref:'User'},
    movie: {type: Schema.Types.ObjectId, ref:'Movie'},
    date: {type: Date, default: Date.now},
    content: String
}, { usePushEach: true });

module.exports = mongoose.model('Review', schema);

我已经填充了我从服务器抓取的电影对象的评论属性,但我想知道如何填充我得到的每个评论对象的用户属性。因此,我没有看到objectId,而是看到了实际的用户对象。

This is what the structure of the movie object I retrieved from the server looks like

我在服务器端的路线:我填写了评论属性,但我不知道如何在这些评论对象中填充用户属性

router.get('/getmovie/:id', function(req, res, next) {
        var id = req.params.id;

    Movie.findById(id, function(err, movie){
            if (err) {
                res.status(500).json({
                    message: "An error occurred",
                    obj: err
                })
            }
            Review.populate(movie, {path: 'reviews'}, function(err, movie){
                if (err) {
                    res.status(500).json({
                        message: "An error occurred",
                        obj: err
                    })
                }
                res.status(200).json({
                    Message: "success",
                    obj: movie
                });
            })
        })
});

1 个答案:

答案 0 :(得分:1)

我认为您可以使用.populate()来简化代码。

Movie.findById(id).populate({
    path: 'reviews',
    populate: {
        path: 'user'
    }
}).exec(function(err, movie){
    if (err) {
        // make sure you add return or else the code will continue
        return res.status(500).json({
            message: "An error occurred",
            obj: err
        })
    }
    res.status(200).json({
        Message: "success",
        obj: movie
    });
});

注意,您最多只能执行2个级别。否则,您需要使用更复杂的.aggregate()