Mongoose deep populate导致[Object]在第2级

时间:2017-10-17 16:38:13

标签: javascript node.js mongodb mongoose mongoose-populate

在花了一天的时间尝试完成任务后,我认为是时候寻求帮助了。

我想填充文档的2个级别。

我尝试使用populate()但它似乎只适用于第一级,而不是深度填充!我在SO上阅读了很多,我知道它应该有用,但我想我错过了一些非常愚蠢的东西......

请让我知道我在哪里犯错误。

以下是相关代码。

架构

var compositionSchema = new Schema({
    name: {
        type: String,
        required: true
    },
    contributions: [{
        type: Schema.Types.ObjectId,
        ref: 'Contribution'
    }]
});
mongoose.model('Composition', compositionSchema);

var contributionSchema = new Schema({
    name: {
        type: String,
        required: true
    },
    media: {
        type: Schema.Types.ObjectId,
        ref: 'Media'
    }
});
mongoose.model('Contribution', contributionSchema);

var mediaSchema = new Schema({
    name: {
        type: String,
        required: true
    }
});
mongoose.model('Media', mediaSchema);

保存在MongoDB中的实际文档

组合物:

{
    "_id" : ObjectId("59e5db4595fe650a71fb0e07"),
    "name" : "Test Pop 7",
    "contributions" : [ 
        ObjectId("59e5db4595fe650a71fb0e05")
    ]
}

贡献:

{
    "_id" : ObjectId("59e5db4595fe650a71fb0e05"),
    "name" : "Honda",
    "media" : ObjectId("59e4ac5dacacd709eac2c856")
}

媒体:

{
    "_id" : ObjectId("59e4ac5dacacd709eac2c856"),
    "name" : "Logo_big.png",
    "width" : 662,
    "height" : 540
}

我的尝试(=错误的代码?)

在Node JS中,当我这样做时(根据文档):

Composition.findOne({ name: "Test Pop 7" })
        .populate({
            path: 'contributions',
            model: 'Contribution',
            populate: {
                path: 'media',
                model: 'Media',
            }
        })
        .exec((error, doc) => {
            if (error) { console.log(error); }
            else {
                console.log(doc);
            }
        });

打印出来,而不实际填充媒体字段:

{ _id: 59e5db4595fe650a71fb0e07,
  name: 'Test Pop 7',
  contributions: 
   [ { _id: 59e5db4595fe650a71fb0e05,
       name: 'Honda',
       media: [Object] } ]
}

1 个答案:

答案 0 :(得分:1)

它有效,请记住问题中的关键词:打印。使用console.log()打印时,它只会向您显示某个(第二)嵌套级别的数组中包含的文档的type(用typeof检查)。如果你这样做:

console.log(doc.contributions[0].media[0])

您将看到已填充的media文档。