我有ActorCollections和Movies的模式:
var mongoose = require("mongoose");
var movieSchema = new mongoose.Schema({
title : String,
score : Number,
year : String,
imdbId : String,
timestamp: { type : Date, default: Date.now },
});
var actorCollectionSchema = new mongoose.Schema({
imdbId : String,
movies: [movieSchema],
actor: String,
timestamp: { type : Date, default: Date.now },
});
module.exports = mongoose.model('ActorCollection', actorCollectionSchema);
我想形成一个首先找到正确的actorCollection的查询,然后从该actorCollection.movies数组中找到某个属性的电影。
我试过了
ActorCollection.findOne({imdbId: imdbId}, function(err, collection){
//collection.movies is my array
// any mongoose methods to query this array???
}
我也看过使用$ elemMatch查找嵌套在子文档中的项的方法,但我不确定如何首先按ActorCollection进行过滤。如果多个演员出现在同一部电影中,我无法分辨我将修改哪个ActorCollection。
有什么想法吗?我可以以某种方式组合查询来实现这一目标吗?
答案 0 :(得分:1)
使用elemMatch
:
ActorCollection
.findOne({"imdbId": imdbId)
.elemMatch("movies", {"title":"foo"})
.exec(cb);
答案 1 :(得分:1)
这最终为我工作。我不得不将查询分成单独的参数。
ActorCollection.findOne({
imdbId: imdbId,
},
{
movies: { $elemMatch: {
title: "Movie title"
}},
}, function(err, movie){
movie
})