[英]How to save array data in nodejs using mongoose?
我被困在mongoDb中保存数据。 这里的数据在数组中,如果mongodb没有,我需要插入数据。 请查看代码:-
var contactPersonData = [{
Name: 'Mr. Bah',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'Mr. Sel',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'Mr.ATEL',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'ANISH',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'sunny ji',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'ashish',
Organization: 'Ashima Limited - Point 2'
}]
console.log('filedata', contactPersonData);
var escapeData = [];
var tempArr = [];
function saveContact(personObj, mainCallback) {
var tempC = personObj['Organization'].trim();
var insertData = {};
Contact.findOne({ companyName: tempC })
.exec(function(err, contact) {
if (err)
return mainCallback(err);
console.log('find com', contact)
if (contact) {
//document exists
mainCallback(null, insertData);
} else {
var newContact = new Contact({ companyName: tempC, createdBy: '58ae5d18ba71d4056f30f7b1' });
newContact.save(function(err, contact) {
if (err)
return mainCallback(err);
console.log('new contact', contact)
insertData.contactId = contact._id;
insertData.name = personObj['Name'];
insertData.email = personObj['Email'];
insertData.contactNumber = { number: personObj['Phone'] };
insertData.designation = personObj['Designation'];
tempArr.push(insertData);
mainCallback(null, insertData);
})
}
});
}
async.map(contactPersonData, saveContact, function(err, result) {
console.log(err)
console.log(result)
},
function(err) {
if (err)
return next(err);
res.status(200).json({ unsaved: escapeData })
})
按照上面的代码,它必须插入六个文档而不是一个。 我认为上述迭代迫不及待要完成上一个迭代。 因此, if
条件始终为false
并执行else
。
您的saveContact()
函数很好。 之所以得到6个文档而不是1个文档,是因为async.map()
可以并行运行代码。 所有这6个请求是并行进行的,而不是一个接一个地进行。
从async.map()
函数的文档中-
请注意,由于此函数并行地将iteratee应用于每个项目,因此不能保证iteratee函数将按顺序完成。
结果,在数据库中创建文档之前,所有查询已经运行,并且所有6个查询都无法找到该文档,因为该文档仍在创建过程中。 因此,您的saveContact()
方法将创建所有6个文档。
如果再次运行代码,则将不再形成文档,因为到那时您的文档将被形成。
您应该尝试使用async.mapSeries()
运行代码以async.mapSeries()
处理请求。 只需在上面的代码mapSeries()
map()
替换为mapSeries()
。 这样,它将等待一个请求完成,然后执行另一个请求,结果将仅创建一个文档。 有关async.mapSeries()
更多信息, async.mapSeries()
点击此处 。
您似乎在使用async.map()
错误。
首先, async.map()仅具有3个参数(即coll
, iteratee
和callback
),那么为什么有4个呢? 在你的情况, coll
是你contactPersonData
, iteratee
是你saveContact
功能, callback
是一个匿名函数。
其次,使用async.map()
是创建一个新数组。 您不是以这种方式使用它,而是像async.each()
那样使用它。
第三,您可能应该依次而不是并行地遍历元素。 因此,您应该使用async.mapSeries()而不是async.map()
。
这是我修改/缩短代码的方法:
var contactPersonData = [{
Name: 'Mr. Bah',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'Mr. Sel',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'Mr.ATEL',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'ANISH',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'sunny ji',
Organization: 'Ashima Limited - Point 2'
}, {
Name: 'ashish',
Organization: 'Ashima Limited - Point 2'
}];
function saveContact(personObj, mainCallback) {
var tempC = personObj.Organization.trim();
Contact.findOne({ companyName: tempC }, function (err, contact) {
if (err)
return mainCallback(err);
console.log('found contact', contact);
// document exists, so mark it as complete and pass the old item
if (contact)
return mainCallback(null, contact);
// document does not exist, so add it
contact = new Contact({ companyName: tempC, createdBy: '58ae5d18ba71d4056f30f7b1' });
contact.save(function (err, contact) {
if (err)
return mainCallback(err);
console.log('created new contact', contact)
// mark it as complete and pass a new/transformed item
mainCallback(null, {
contactId: contact._id,
name: personObj.Name,
email: personObj.Email, // ??
contactNumber: { number: personObj.Phone }, // ??
designation: personObj.Designation // ??
});
});
});
};
async.mapSeries(contactPersonData, saveContact, function (err, contacts) {
if (err)
return next(err);
// at this point, contacts will have an array of your old and new/transformed items
console.log('transformed contacts', contacts);
res.json({ unsaved: contacts });
});
就??
注释,这意味着您的contactPersonData
没有这些属性,因此将是undefined
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.