如何将所有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”......等等。
如何防止此问题?
答案 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();
}
);
});