0

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

1 回答 1

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");
    });
});
于 2013-08-27T20:23:20.337 回答