2

以下是显示问题的函数:

var mongoose = require('mongoose');
var connection = mongoose.createConnection('mongodb://localhost:27017');

connection.once('open', function () {
  var schema = new mongoose.Schema({
    obj: [{}] //mongoose.Schema.Types.Mixed
  });

  var Model = connection.model('mtest', schema);
  var model = new Model({
    obj: [{ name: 'Original' }]
  });

  model.save(function (err, res) {
    console.log('result 1', res);

    Model.findOne({_id: res._id}, function (err, res) {
      res.obj[0].name = 'Modified';
      res.obj.push({ name: 'other' });
      //res.markModified('obj'); // using markModified does not help

      res.save(function (err, res) {
        console.log('result 2', res);
        connection.close();
        process.exit();
      });
    });
  })
});

“结果 2”的输出显示Modified“obj”中第一项的“”:obj: [ { name: 'Modified' }, { name: 'other' } ]。但是,在数据库中,第一项的值仍然是“ Original”。

这仅在将第二项推入数组时发生(否则第一项确实被修改)。添加markModified确实可以解决问题。

我在模式中使用了一组空对象类型,因为实际上这个用例处理的是相互继承的模式,所以这里不能使用单一模式。

它是一个错误吗?我发现的唯一解决方法是清除数组并再次添加所有项目。我想知道是否有更好的解决方案。

4

1 回答 1

1

您可以更改markModified调用以识别您在数组访问方法“外部”更改的元素的索引:

res.obj[0].name = 'Modified';
res.obj.push({ name: 'other' });
res.markModified('obj.0');

或者切换到使用set数组访问方法来发出警报name(这看起来很愚蠢,但确实有效):

res.obj[0].name = 'Modified';
res.obj.set(0, res.obj[0]);
res.obj.push({ name: 'other' });
于 2015-12-09T14:56:38.357 回答