MongoDB-Native NodeJS更新失败

时间:2011-09-23 11:44:29

标签: javascript mongodb node.js

我有一个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){});

它运作得很好。

1 个答案:

答案 0 :(得分:3)

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

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

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

E.g:

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