猫鼬用数组元素的条件填充嵌套数组
mongoose populate nested array with condition for array element
我有一个包含文章的文章组,模型看起来像这样
var ArticleGroup = new mongoose.Schema({
articles:[{type:mongoose.Schema.Types.ObjectId,ref:'Article'}]
})
var Article = new mongoose.Schema({
rates:[{
uid:String,
rate:Number //user's rate number to this article
}]
})
现在 一个用户(我们称他为 JACK) 想要对 ArticleGroup 执行查询,填充该组中的文章,选择提交的费率
通常我这样做
ArticleGroupModel
.findById(articleGroupId)
.populate('articles','rates')
.select('articles')
.exec((err, articleGroup) => {
if (err) return next(err)
//...
})
但现在我只想要 JACK 的价格
如果一篇文章有 JACK 的评分,就 return 那篇文章像这样
{
_id:"23jrf23orj89p3fwje4",
rates:[{
uid:"JACK's uid",
rate:"JACK's rate number"
}]
}
如果一篇文章没有 JACK 的费率,该文章仍会填充,但会像这样归档空费率
{
_id:"23jrf23orj89p3fwje4",
rates:[]
}
有什么办法吗?
为了获得这个结果,您应该重新考虑您的数据模型,如下所示:
ArticleGroup = new mongoose.Schema
some details here ...
ArticleRate = new mongoose.Schema
uid: String
rate: Number
Article = new mongoose.Schema
group:
type: mongoose.Schema.ObjectId
ref: 'ArticleGroup'
rates:[ArticleRate]
并执行这种查询:
Article
.find(group: groupId)
.populate({
path: 'rates',
match: { uid: { $in: { JACK_UID } } },
select: 'rate'
})
.exec();
您可以在 Mongoose documentation 中找到更多有用的信息。
我有一个包含文章的文章组,模型看起来像这样
var ArticleGroup = new mongoose.Schema({
articles:[{type:mongoose.Schema.Types.ObjectId,ref:'Article'}]
})
var Article = new mongoose.Schema({
rates:[{
uid:String,
rate:Number //user's rate number to this article
}]
})
现在 一个用户(我们称他为 JACK) 想要对 ArticleGroup 执行查询,填充该组中的文章,选择提交的费率
通常我这样做
ArticleGroupModel
.findById(articleGroupId)
.populate('articles','rates')
.select('articles')
.exec((err, articleGroup) => {
if (err) return next(err)
//...
})
但现在我只想要 JACK 的价格 如果一篇文章有 JACK 的评分,就 return 那篇文章像这样
{
_id:"23jrf23orj89p3fwje4",
rates:[{
uid:"JACK's uid",
rate:"JACK's rate number"
}]
}
如果一篇文章没有 JACK 的费率,该文章仍会填充,但会像这样归档空费率
{
_id:"23jrf23orj89p3fwje4",
rates:[]
}
有什么办法吗?
为了获得这个结果,您应该重新考虑您的数据模型,如下所示:
ArticleGroup = new mongoose.Schema
some details here ...
ArticleRate = new mongoose.Schema
uid: String
rate: Number
Article = new mongoose.Schema
group:
type: mongoose.Schema.ObjectId
ref: 'ArticleGroup'
rates:[ArticleRate]
并执行这种查询:
Article
.find(group: groupId)
.populate({
path: 'rates',
match: { uid: { $in: { JACK_UID } } },
select: 'rate'
})
.exec();
您可以在 Mongoose documentation 中找到更多有用的信息。