如何使用mongoose.js合并更新文档?

时间:2012-12-03 22:41:49

标签: ajax node.js mongodb express mongoose

我有一个模式的模型:

schema = new Schema({
    name: String,
    sections: [{
        name: String,
        columns: [{
            name: String      
        }]
    }]
}];

//Lets call the model a Page

为简单起见,我检索整个模型:

app.get('/page/:name', function(req, res){
    Page.findOne( {name: req.params.name}, function(err, page){
        //error handling
        res.send page
    });
});

请求GET / page / myPage我收到:

{
    //_id, __v, etc..
    name: 'myPage',
    sections: [{
        name: 'Section 1',
        columns [{
            name: 'My #1 Column'
        }]
    }]
}

我将列0名称更改为My#1列FOOBAR!在客户端

{
    //_id, __v, etc..
    name: 'myPage',
    sections: [{
        name: 'Section 1',
        columns [{
            name: 'My #1 Column FOOBAR!'
        }]
    }]
}

另一位用户添加一个名称为“My#2 Column !!!”

的列
   {
        //_id, __v, etc..
        name: 'myPage',
        sections: [{
            name: 'Section 1',
            columns [{
                name: 'My #1 Column'
            },
            {
                name: 'My #2 Column!!!'
            }]
        }]
    }

两个用户都将整个不同步JSON发布到服务器。我想合并他们。

这是我目前的保存方法:

app.post('/page/save', function(req, res) {
  var newPage = req.body.page;

  Page.findOne({
    _id: newPage._id
  }, function(err, page) {
    if (err) {
      return res.send(err);
    }

    // this portion is obviously problematic as it doesn't merge the objects
    // it simply overwrites it with whatever page JSON you received at the time
    // of the request.
    page.sections = newPage.sections;

    page.save(function(err) {
      if (err) {
        res.send(err);
      } else {
        res.send('success!');
      }
    });

  });
});

我是否需要创建自己的更新队列,首先从服务器检索最新文档,将文档合并在一起然后保存。或者这是由mongodb处理的。

此外,是否有一个简单的方法,如更新,将旧对象与新对象合并,并保存?

谢谢。

3 个答案:

答案 0 :(得分:1)

http://mongoosejs.com/docs/api.html#document_Document-update

每个文档都有update方法可用。希望有所帮助。

答案 1 :(得分:1)

我这样做:

.put('/:pr_id', (req, res, next) => {
      let pr_id = req.params.pr_id;


      PR.findById(pr_id, (err, doc) => {
        if (err) {
          return res.status(500).json({error: err});
        }
        if (!doc){
          return res.status(404).json({error: 'Document not found'});
        }

        let updated = req.body.pr;
        Object.assign(doc, updated);

        doc.save((err) => {
          if (err) {
            return res.status(500).json({error: err});
          }

          res.json(doc);
        });
      });

Object.assign基本上合并了两个对象(https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign

答案 2 :(得分:0)

_.merge方法可以使用警告:您无法合并mongoose文档,它必须是.lean()找到的或使用.toObject()转换的普通对象

Model.update({
  _id: doc._id
}, {
  $set: _.merge(doc.toObject(), {
    stuff: {
      hello: 'world'
    }
  })
})