如何处理Mongoose文档版本错误

9

在更新同一文档时,我遇到了这个错误。我不断从套接字获取数据并更新文档。但是最近的数据尚未更新,当套接字发出更新相同文档的新数据时。那么我该如何处理此错误或等待回调该文档?

{ Error
at model.wrappedPointCut [as save] (/var/www/html/parcel-app/node_modules/mongoose/lib/services/model/applyHooks.js:131:29)
at /var/www/html/parcel-app/server/server.js:372:22
at /var/www/html/parcel-app/node_modules/mongoose/lib/query.js:3115:18
at tryCatcher (/var/www/html/parcel-app/node_modules/bluebird/js/main/util.js:26:23)
at Promise._settlePromiseFromHandler (/var/www/html/parcel-app/node_modules/bluebird/js/main/promise.js:510:31)
at Promise._settlePromiseAt (/var/www/html/parcel-app/node_modules/bluebird/js/main/promise.js:584:18)
at Promise._settlePromises (/var/www/html/parcel-app/node_modules/bluebird/js/main/promise.js:700:14)
at Async._drainQueue (/var/www/html/parcel-app/node_modules/bluebird/js/main/async.js:123:16)
at Async._drainQueues (/var/www/html/parcel-app/node_modules/bluebird/js/main/async.js:133:10)
at Immediate.Async.drainQueues (/var/www/html/parcel-app/node_modules/bluebird/js/main/async.js:15:14)
at runCallback (timers.js:800:20)
at tryOnImmediate (timers.js:762:5)
at processImmediate [as _immediateCallback] (timers.js:733:5)
message: 'No matching document found for id "5ae99a15e5e73b39cacafe48"',
name: 'VersionError' }

这里是代码片段。
  socket.on('sendUserLocation', function(data) {
  //when app send new location of user this method will invoked
  if (data !== undefined) {
    var lat = data.lat;
    var lng = data.lng;
    var userType = data.user_type;
    var roomName = data.room_name;
    var heading = data.heading != undefined ? data.heading : 0;

    if (userType == 'db') {
      var returnBoj = {
        lat: lat,
        lng: lng,
        user_type:'db',
        room_name: roomName,
        heading: heading, //heading is degree of db boy which will -180-0-180
      };
      //finding user by room id which is user document id mongoose
      DeliveryboyModel.findById(roomName).exec(function (err, DBData) {
        if (DBData) {
          locationArray = [ parseFloat(lat) , parseFloat(lng) ];
          DBData.locationDetails.location = locationArray;
          DBData.save(function (err) {
             //getting error here
            if (err) {
              console.log(err);
            }
          });
        }
      });

      // emmiting addnewmarker so customer app will get new location and will update pin to new location
      socket.emit('addnewmarker', returnBoj);
      socket.broadcast.to(roomName).emit('addnewmarker', returnBoj);
    }
  }
});

我的端口也出现了同样的错误,请帮帮我。 - Rahul Saini
需要更多相同的代码。 - Ritwick Dey
1
提供模式和代码片段,从中我们正在尝试创建。 - Arif Khan
你能提供你所遵循的操作顺序吗?根据提供的描述,无法重现该问题。 - Pruthvi Kumar
@RitwickDey 添加了 - Ajarudin Gunga
1个回答

5
错误信息提示无法找到文档,所以如果是本地查询,请尝试使用ObjectId进行包装,例如:ObjectId("507f1f77bcf86cd799439011")
关于如何等待文档或处理错误,取决于您的数据库驱动程序。例如,如果您正在使用promised-mongo:
db.collection.update(...).then((doc) => {
  // This will run once updated
}).catch((err) => { //handle the error});

如果您正在使用 mongodb npm 模块:

阅读更多:https://github.com/gordonmleigh/promised-mongo

db.collection.update({_id: ObjectId('yourId'), {updateKey: 
'updateVal}, (err,val) => {
  if(err) //handle it and return
  // update finished
  return callback(doc);
});

更多细节请参考https://www.npmjs.com/package/mongodb

如果问题仍然存在,请尝试使用标志{upsert: true}设置查询,如此处所述。

请注意,传入的套接字消息可能不总是按照发送顺序到达,请适当处理状态或使用队列。


1
是的,它有效!!已更新为基于 Promise 的查询,并使用 => 操作符。现在不会抛出错误了。 - Ajarudin Gunga

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接