2016-09-15 13 views
0

私はコレクションをループして、関連するコレクションからオブジェクトの配列を追加しようとしています。私が得ている結果にはその配列が含まれていません。 誰でも問題を見つけられるでしょうか?async.mapが期待通りに動作しない

モデル関係には多くの質問があります。

質問スキーマ:

var mongoose = require('mongoose'), 
    Schema = mongoose.Schema; 

    var questionSchema = new Schema({ 
     _poll     : { type: Schema.Types.ObjectId, ref: 'Poll' }, 
     _page     : { type: Schema.Types.ObjectId, ref: 'Page' }, 
     type     : { type : String, required: true }, 
     title     : { type : String, required: true }, 
     required    : { type : Boolean }, 
     help_text    : { type : String }, 
    }, 
    { timestamps: { createdAt: 'created_at', updatedAt: 'updated_at' } 
    }); 

    mongoose.model('Question', questionSchema); 

ページスキーマ:

var mongoose = require('mongoose'), 
Schema = mongoose.Schema; 

var pageSchema = new Schema({ 
    _poll    : { type: Schema.Types.ObjectId, ref: 'Poll' }, 
    title    : { type : String, required: true }, 
    intro    : { type : String }, 
    list_style_type : { type : String }, 
}, 
{ timestamps: { createdAt: 'created_at', updatedAt: 'updated_at' } 
}); 

mongoose.model('Page', pageSchema); 

ルート

度:関数(REQ、RES、次){

Poll.findOne({_id: req.params.poll_id}, function(err, poll){ 
    if(err) return next(err); 

    Page.find({_poll: poll.id}, function(err, pages){ 
    if(err) return next(err); 

    async.map(pages, function(p, done) { 
     Question.find({_page: p._id}, function(err, q){ 
     if(err) return next(err); 
     p.questions = q; // <-- SHOULDN'T THIS WORK? // 
     done(null, pages); 
     }); 
    }, function(err, result) { 
     if(err) return next(err); 
     res.status(200).json(pages); 
    }) 

    }); 
}); 

}、

結果、私は取得しています:

[ 
    { 
    _id: "57d960fb569dc4101a83525e", 
    updated_at: "2016-09-14T14:38:51.113Z", 
    created_at: "2016-09-14T14:38:51.113Z", 
    _poll: "57c88775992af4c84f99c5d0", 
    title: "test section", 
    list_style_type: "lower-roman", 
    __v: 0 
    }, 
    { 
    _id: "57d9691e22eb81583e20a1c1", 
    updated_at: "2016-09-14T15:13:34.244Z", 
    created_at: "2016-09-14T15:13:34.244Z", 
    _poll: "57c88775992af4c84f99c5d0", 
    title: "this is a new page", 
    list_style_type: "lower-roman", 
    intro: "jkc hcsad", 
    __v: 0 
    }, 
    { 
    _id: "57d9a97d1e7863b81f9e4d0e", 
    updated_at: "2016-09-14T19:48:13.816Z", 
    created_at: "2016-09-14T19:48:13.816Z", 
    _poll: "57c88775992af4c84f99c5d0", 
    title: "Consequatur Vero necessitatibus consequatur hic", 
    list_style_type: "upper-latin", 
    intro: "Rem laboris est omnis ducimus, minim autem itaque minim dolore ea odio aliqua. Autem qui id, sit nulla id.", 
    __v: 0 
    }, 
    { 
    _id: "57dab7d7f54387d41d976614", 
    updated_at: "2016-09-15T15:01:44.001Z", 
    created_at: "2016-09-15T15:01:44.001Z", 
    _poll: "57c88775992af4c84f99c5d0", 
    title: "This is a new page", 
    list_style_type: "lower-roman", 
    intro: "cjksahc dsa", 
    __v: 0 
    } 
] 

は、私は、配列「質問」を含むように返されたオブジェクトを期待何とかそれはありません。

ありがとうございます!

答えて

0

「ルート」コードに、間違った変数がコールバックに渡された可能性があります。 done(null, pages)done(null, p)で、res.status(200).json(pages)res.status(200).json(result)である必要があります。

mongooseはスキーマに存在しないフィールドを無視するため、questionsは結果に表示されません。 "ルート"コードでは、pはmongooseドキュメントで、.toObject()で平易なjavascriptオブジェクトに変換できます。正しい

async.map(pages, function(p, done) { 
    Question.find({_page: p._id}, function(err, q){ 
    if(err) return next(err); 
    p = p.toObject(); // convert a mongoose document into a javascript object 
    p.questions = q; 
    done(null, p); // modified 'pages' -> 'p' 
    }); 
}, function(err, result) { 
    if(err) return next(err); 
    res.status(200).json(result); // modified 'pages' -> 'result' 
}) 
+0

だから、多分あなたは次のようにコードを置き換えることにより、questionsで結果を得ることができます。私は、マングースがスキーマの一部ではないフィールドを返さなかったことを知らなかった!あなたのお時間をありがとうございました! :) – rsilva

関連する問題