在我的MEAN应用程序中,我有一种情况,我在逐行读取一些csv数据,并使用'upsert'更新现有记录,以及插入那些与' CSCOpportunityID'字段值:
if(metaFields.subjectCategory === 'SalesforceData'){
//Here we will use the upsert logic to either insert new, or update existing records
for (var i = 0; i < result.length; i++) {
//console.log(result[i]);
var inserted = 0;
for (var i = 0; i < result.length; i++) {
var dataRecord = result[i];
dataRecord.OriginalDocumentName = fileName;
dataRecord.DocumentAuthor = metaFields.documentAuthor;
dataRecord.TabName = tabName;
dataRecord.SubjectCategory = metaFields.subjectCategory;
dataRecord.Subject = metaFields.subject;
dataRecord.DateDocumentProduced = metaFields.dateDocumentProduced;
dataRecord.DateDocumentReceived = metaFields.dateDocumentReceived;
dataRecord.DocumentSubmitter = metaFields.documentSubmitter;
dataRecord.DocumentReviewer = metaFields.documentReviewer;
dataRecord.OriginalSource = metadataFields.originalSource,
dataRecord.DataVersion = metadataFields.dataVersion,
dataRecord.DataFields = newCsvLines[0];
collection.update(
{
CSCOpportunityId: dataRecord.CSCOpportunityID
},
{
$set: {
OriginalDocumentName: dataRecord.OriginalDocumentName,
DocumentAuthor: dataRecord.DocumentAuthor,
TabName: dataRecord.TabName,
SubjectCategory: dataRecord.SubjectCategory,
Subject: dataRecord.Subject,
DateDocumentProduced: dataRecord.DateDocumentProduced,
DateDocumentReceived: dataRecord.DateDocumentReceived,
DocumentSubmitter: dataRecord.DocumentSubmitter,
DocumentReviewer: dataRecord.DocumentReviewer,
OriginalSource: dataRecord.OriginalSource,
DataVersion: dataRecord.DataVersion,
DataFields: dataRecord.DataFields,
CSCOpportunityID : dataRecord.CSCOpportunityID,
OpportunityName: dataRecord.OpportunityName ,
AccountName : dataRecord.AccountName,
OpportunityOwner : dataRecord.OpportunityOwner,
Stage : dataRecord.Stage,
Industry : dataRecord.Industry,
ACV : dataRecord.ACV,
RevenueStartDate : dataRecord.RevenueStartDate,
RevenueTerm : dataRecord.RevenueTerm,
ProbabilityPct : dataRecord.ProbabilityPct,
DealRegion : dataRecord.DealRegion
}
},
{upsert: true},
{multi:true}
//if (++inserted == result.length) {
// console.log("finished");
// //db.close();
//}
);
}
}
}
更新部分有效,但插入部分不起作用,因为当'CSCOpportunityID'的值找不到匹配项时,我不知道如何进行插入。
处理此问题的正确方法是什么?
答案 0 :(得分:2)
update
方法将第四个参数作为回调函数。由于您提供了一个对象{multi: true}
,它不会进行任何db调用,只返回一个promise。正确的语法是:
collection.update(query, fieldsToSet, {upsert: true, multi: true}, function(err,doc){
})