猫鼬:在find()之后填充

时间:2015-01-23 00:18:51

标签: node.js mongodb express mongoose

我是mongo和node js的新手,这是我尝试做的事情:

API将根据查询检查数据库中是否存在现有条目。

  • (a)如果没有现有文档,则创建一个新文档,填充,发送到 客户。
  • (b)如果文档存在,则返回文档,填充,发送到 客户端。

问题:在方案(a)中,在创建文档后,API发送" null"给客户。

怀疑: .populate()& .exec()在API完成创建新文档之前运行。代码中的代码片段返回null:

console.log('Inside IF' + video_res); // returns null

解决此问题的最佳方法是什么?

model_video.findOne( video_entry, 
        function(err, video_req) { // Send Back Object ID
            if (err) res.send(err);

        if (!video_req) { // Does not work
            console.log('-----STATUS : No Video Found');

            model_video.create(video_entry, function(err, video_res) {
                    console.log('Call back activated');
                    if (err) res.send(err);

                    console.log('Response is ' + video_res);
                    return video_res; // Does not work here!
            }); // Ends - Create
            console.log('Inside IF ' + video_res);
        } 

        else { // Works
            console.log('-----STATUS : Video Found')
            if (err) return res.send(err);
            var video_res = video_req;
            console.log('Response is ' + video_res);
            return video_res;
        };
    })
    .populate('_chirps')
    .exec(function(err, video_res) {
        if (err) return res.send(err);
        res.json(video_res);
        console.log('Final Output is ' + video_res)
    });

};

非常感谢您的帮助!

1 个答案:

答案 0 :(得分:2)

回调exec()回调在.findOne查询后立即执行,您需要将其余代码放在该回调中。我已经重构了您的代码,使其更符合您的尝试。

model_video.findOne(video_entry)
.populate('_chirps')
.exec(function(err, video_res) {
  if (err) return res.send(err);

  if (video_res) {
    console.log('-----STATUS : Video Found')
    console.log('Response is ' + video_res);
    res.json(video_res)
  }
  else {
    console.log('-----STATUS : No Video Found');

    model_video.create(video_entry, function(err, new_video_res) {
      if (err) return res.send(err);

      console.log('Response is ' + new_video_res);
      res.json(new_video_res);
    });
  }
})