繁体   English   中英

如何使用猫鼬在nodejs中保存数组数据?

[英]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个参数(即colliterateecallback ),那么为什么有4个呢? 在你的情况, coll是你contactPersonDataiteratee是你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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM