我有这样的查询: galleryModel.find({_id: galleryId}) .populate({ model: 'User', path: 'objectId', select: 'firstName lastName' }) objectId的结束响应如下: objectId: {...} 如何在不改变实际路径的情况下将其更改为
          galleryModel.find({_id: galleryId})
            .populate({
                model: 'User',
                path: 'objectId',
                select: 'firstName lastName'
            }) 
 objectId的结束响应如下:
objectId: {
...
} 
 如何在不改变实际路径的情况下将其更改为用户响应?
您可以通过mongoose 4.5版中引入的virtual populate来完成此操作.为此,您需要在mongoose模式中定义虚拟字段.var GallerySchema = new mongoose.Schema({
    name: String,
    objectId: {
        type: mongoose.Schema.Types.ObjectId
    },
});
GallerySchema.virtual('user', {
    ref: 'User',
    localField: 'objectId', 
    foreignField: '_id' 
}); 
 当你运行查询查询时,只需用用户填充它.
Gallry.find({_id: galleryId}).populate('user','firstName lastName').exec(function(error, gallery) {
    console.log(error);
    console.log(gallery);;
}); 
 以上代码未在程序中测试,可能存在拼写错误,您可以在下面的链接中获取有关mongoose虚拟填充的更多详细信息
http://mongoosejs.com/docs/populate.html
