[英]How can I query MongoDB sub documents using 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 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。
有任何想法嗎? 我可以以某種方式組合查詢來實現此目的嗎?
使用elemMatch
:
ActorCollection
.findOne({"imdbId": imdbId)
.elemMatch("movies", {"title":"foo"})
.exec(cb);
最終為我工作。 我不得不將查詢分為單個參數。
ActorCollection.findOne({
imdbId: imdbId,
},
{
movies: { $elemMatch: {
title: "Movie title"
}},
}, function(err, movie){
movie
})
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.