Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何使用mongoose查询MongoDB子文档?_Javascript_Mongodb_Mongoose - Fatal编程技术网

Javascript 如何使用mongoose查询MongoDB子文档?

Javascript 如何使用mongoose查询MongoDB子文档?,javascript,mongodb,mongoose,Javascript,Mongodb,Mongoose,我有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 acto

我有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

有什么想法吗?我能否以某种方式组合查询以实现此目的?

使用:


这最终对我有用。我不得不将查询拆分为单独的参数

ActorCollection.findOne({
        imdbId: imdbId,
    },
    {
        movies: { $elemMatch: {
            title: "Movie title"
        }},
    }, function(err, movie){
        movie
    })

你可以接受解决你问题的任何答案。
ActorCollection.findOne({
        imdbId: imdbId,
    },
    {
        movies: { $elemMatch: {
            title: "Movie title"
        }},
    }, function(err, movie){
        movie
    })