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

Jes*_*rle 5 ajax mongoose mongodb node.js express

我有一个带有架构的模型:

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

//Lets call the model a Page
Run Code Online (Sandbox Code Playgroud)

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

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

通过请求 GET /page/myPage 我收到:

{
    //_id, __v, etc..
    name: 'myPage',
    sections: [{
        name: 'Section 1',
        columns [{
            name: 'My #1 Column'
        }]
    }]
}
Run Code Online (Sandbox Code Playgroud)

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

{
    //_id, __v, etc..
    name: 'myPage',
    sections: [{
        name: 'Section 1',
        columns [{
            name: 'My #1 Column FOOBAR!'
        }]
    }]
}
Run Code Online (Sandbox Code Playgroud)

另一个用户添加了一个列,名称为:“My #2 Column!!!”

   {
        //_id, __v, etc..
        name: 'myPage',
        sections: [{
            name: 'Section 1',
            columns [{
                name: 'My #1 Column'
            },
            {
                name: 'My #2 Column!!!'
            }]
        }]
    }
Run Code Online (Sandbox Code Playgroud)

两个用户将整个不同步的 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!');
      }
    });

  });
});
Run Code Online (Sandbox Code Playgroud)

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

另外,是否有像 update 这样的简单方法,可以将旧对象与新对象合并并保存?

谢谢。

Bel*_*dar 7

我这样做:

.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);
        });
      });
Run Code Online (Sandbox Code Playgroud)

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


Pie*_*eau -1

_.merge方法可以与警告一起使用:您不能合并猫鼬文档,它必须是一个普通对象,可以通过以下方式找到.lean()或通过以下方式转换.toObject()

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