MongoDB-Native NodeJS更新失败

MongoDB-Native NodeJS Update Fails

本文关键字:失败 更新 NodeJS MongoDB-Native      更新时间:2023-09-26

我有一个MongoDB 2.0与NodeJS 0.4.11一起安装,我正试图做一个数据库的更新。下面是代码:

var mongo = require('mongodb');
var db = new mongo.Db('db', new mongo.Server('localhost', 27017, {}), {});
var updatecmd = JSON.parse(JSON.stringify("{ id : " + jsonObj.VisitorID + "}"));
console.log(updatecmd);
var insertObject = JSON.parse(JSON.stringify(temp));
col.update(updatecmd, insertObject, {upsert:true}, function(err, r){console.log(err.stack); console.log(r);});

col.save()工作正常,但当我将其更改为col.update时,我得到以下错误:

TypeError: Object.keys called on non-object
    at Function.keys (native)
    at Function.calculateObjectSize (/home/admin/node_modules/mongodb/lib/mongodb/bson/bson.js:76:34)
    at [object Object].toBinary (/home/admin/node_modules/mongodb/lib/mongodb/commands/update_command.js:43:112)
    at [object Object].send (/home/admin/node_modules/mongodb/lib/mongodb/connection.js:257:32)
    at [object Object].executeCommand (/home/admin/node_modules/mongodb/lib/mongodb/db.js:746:18)
    at Collection.update (/home/admin/node_modules/mongodb/lib/mongodb/collection.js:421:26)
    at addtoobject (/home/admin/mongoscript.js:127:9)
    at /home/admin/mongoscript.js:103:4
    at EventEmitter.<anonymous> (/home/admin/node_modules/lazy/lazy.js:62:13)
    at EventEmitter.<anonymous> (/home/admin/node_modules/lazy/lazy.js:46:19)

对于每一个单独的内容,我都会得到这个错误。当我做

col.save(insertObject, function(err,r){});

它工作得很好。

不能100%确定这是否是问题,尽管看起来很可能:

var updatecmd = JSON.parse(JSON.stringify("{ id : " + jsonObj.VisitorID + "}"));

这将输出一个字符串,而不是对象。放弃对stringify的调用,或者最好还是构建对象。

例如:

var ID = 123,
    oldupdatecmd = JSON.parse(JSON.stringify("{ id : " + ID + "}")), // "{id : 123}"
    newupdatecmd = { id : ID }; // {id : 123}   <--  An Object, not a string

很确定第一个参数应该是一个对象,这就是错误看起来像:Object.keys called on non-object