Node.js Mongodb回调问题

时间:2015-08-09 01:28:06

标签: javascript node.js mongodb

如果tmx更新,我的应用程序应该更新,如果旧版本什么也不做,如果不存在则插入文档。 如果插入文档,它可以正常工作,否则它无法正确更新或说E11000重复密钥。 试图弄清楚我的回调是错误还是逻辑。 (我是node.js + mongodb的新手)MongoClient = require('mongodb')。MongoClient,             assert = require('assert'),             url ='mongodb:// localhost:27017 / pfc';

    MongoClient.connect(url, function (err, db) {
        run(db);
    });


    function run(db) {
        fs.readFile('log.log', 'utf8', function (err, source) {
            if (err) throw err;
            var dataFile = JSON.parse(source);
            dataFile.forEach(function (item) {
                upsert(db, item, function (err, result) {
                    if (err) console.dir(err);

                });
            });
        })
    }

    function upsert(db, doc, callback) {

    db.collection('flags').findOne({vid: doc.vid}, function (err, item, result) {

        if (item.vid != null) {
            if (!(item.tmx instanceof Date)) {
                item.tmx = new Date(item.tmx)
            }
            if(!(doc.tmx instanceof Date)){
                doc.tmx = new Date(doc.tmx)
            }

            if (item.tmx < doc.tmx) {
                console.dir("Date validation")
                db.collection('flags').updateOne({vid: item.vid}, {
                        $set: {
                            "tmx": doc.tmx
                        }
                    },{upsert:true}, function (err, result) {
                        callback(err, result);

                    }
                )

                callback(err, result);
            }
            else{
                console.dir("older")
                callback(err, result);
            }
        }
        else {
            db.collection('flags').insertOne(doc, function(err, result) {
                callback(err, result);
            });
        }
    })}

编辑: 'log.log'文件中的文档具有以下结构:

{ VID:2848 tmx:“2015-07-18T23:56:17.000Z” }

{ 视频:2848 tmx:2015-07-19T00:00:17.000Z }

collection.find({vid:doc.vid},function(err,item){

如果(!item)//没有在集合中找到具有vid:2848的项目 将doc插入集合 否则if(item)//找到带有vid的项目:2848   if(item.tmx&lt; doc.tmx)//仅在doc.tmx更新时才更新     使用最新文档更新集合

与@Aaron Dufour帮助我摆脱了回调问题,谢谢:) 但现在的问题是,当我已经填充了集合并在log.log中查找最新文档时,它从最旧的文档开始直到最新文档:(

1 个答案:

答案 0 :(得分:2)

您的upsert容易受到竞争条件的影响,并且run并行多次调用它,因此这可能就是问题所在。目前还不清楚doc究竟是什么样的,所以你可能需要稍微复杂的逻辑,但是这里有一个使用Mongo的upsert来使事情更安全的版本:

function upsert(db, doc, callback) {
  db.collection('flags').update({vid: doc.vid}, {$set: doc}, {upsert: true}, function(err) {
    db.collection('flags').update({vid: doc.vid, tmx: {$lt: doc.tmx}}, {$set: tmx: doc.tmx}, function(err) {
      callback();
    });
  });
}