node.js阻塞,for语句中的非阻塞问题

时间:2018-05-12 01:23:41

标签: node.js express blocking

如何将所有json保存到我的mongoldb? 奇怪的是,每次只存储第一个值。 它可能是阻塞/非阻塞问题。

json = {
  ["name":"Karl","id":"azo0"],
  ["name":"Robert","id":"bdd10"],
  ["name":"Joan","id":"difj90"],
  ["name":"Hallyn","id":"fmak88"],
  ["name":"Michael","id":"vma91"]
};

for(var i = 0; i < json.length; i++){
  id = json[i].id;
  name = json[i].name;

  var ctx = {"id":id,"name":name};
  db.json_db.count(ctx).exec(function(err, count) {
    if(count < 1){
        var model = new User({
           "name":json[i].name,
           "id":json[i].id
        });
        model.save(function(){
            console.log("ok"+i);

        });
    }
  });
};

插入后,所有数据都填充[“name”:“Karl”,“id”:“azo0”] 要查看console.log(“ok”+ i),它总是打印“ok0”而不是“ok1”,“ok2”,“ok3”......等等。

如何防止此问题?

2 个答案:

答案 0 :(得分:1)

.exec()告诉我你正在使用Mongoose。所以你的循环可以重写为:

const json = [
  {name: "Karl", id: "azo0"},
  {name: "Robert", id: "bdd10"},
  {name: "Joan", id: "difj90"},
  {name: "Hallyn", id: "fmak88"},
  {name: "Michael", id: "vma91"}
];

for (const item of json) {
  const count = await db.json_db.count(item).exec()
  if (!count) {
    await new User(item).save()
  }
}

答案 1 :(得分:1)

如果您正在使用Async套餐,这是解决问题的最佳方法......

  async.eachSeries(json, (item, done) => {
   let user = new User(
                     {
                        "name":json[i].name,
                         "id":json[i].id
                    },
                    (err, user) => {
                        if(err){
                           // handle err
                        }
                        return done();
                    }
                );
});