我有这样的查询:
galleryModel.find({_id: galleryId})
.populate({
model: 'User',
path: 'objectId',
select: 'firstName lastName'
})
objectId
的结束回复将如下:
objectId: {
...
}
如何在不改变实际路径的情况下将其更改为user
?
答案 0 :(得分:0)
您可以通过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虚拟填充的更多详细信息