Mongoose的model.update在Node.js中不起作用

时间:2013-08-24 14:17:06

标签: javascript node.js mongodb mongoose

我有一个Node.js应用程序正在使用Mongoose更新MongoDB数据库中的数据。

我已经设置了Mongoose模型,并且我能够成功使用model.find和model.remove函数,但我无法使model.update函数起作用。

任何人都可以帮助我吗?

/* ------------------------ Finding/Querying works ----------------------
Flot.find({ "label": "Trips Per Day"}, function (err, docs) {
  res.jsonp(docs || err);
});
*/



/* ------------------------ Removing works -----------------------
Flot.remove({ "label": "Trips Per Client" }, function (err) {
  if (err) return handleError(err);
  res.json(err || "removed");
});
*/


var conditions = { "label": "Average Tons per Delivery" };
var update = { "label": "Average Tons per Delivery 2" };
var options = { };
var callback = function callback(err, numberAffected, rawResponse) {
    if (err) return handleError(err);

  console.log('Error: ', err);
  console.log('NumberAffected: ', numberAffected);
  console.log('RawResponse: ', rawResponse);

    res.json(err || rawResponse || numberAffected );
};

 Gage.update( conditions, update, options, callback );

1 个答案:

答案 0 :(得分:1)

我能够使用node-mongodb-native进行此操作。我仍然不确定为什么Mongoose没有工作,但至少我得到了一些工作。

var query = {"label": "Average Tons per Delivery"};
var update = {"type": "vertical"};
var options = {};

MongoClient.connect('mongodb://localhost/db', function(err, db) {
  if(err) throw err;

db.collection('justgage').findAndModify(
    query,
    [['_id','asc']],
    {$set: update},
    options,
    function(err, object) {
      res.jsonp("Ok");
    });
});