如何合并使用mongoose.js更新文档?
我有一个模式与模式:
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的名称更改为我的#1列FOOBAR! 在客户端
{ //_id, __v, etc.. name: 'myPage', sections: [{ name: 'Section 1', columns [{ name: 'My #1 Column FOOBAR!' }] }] }
另一位用户添加名为“我的#2列!!!”的列
{ //_id, __v, etc.. name: 'myPage', sections: [{ name: 'Section 1', columns [{ name: 'My #1 Column' }, { name: 'My #2 Column!!!' }] }] }
两个用户都将整个不同步的JSON POST到服务器。 我想合并它们。
这是我目前的保存方法:
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!'); } }); }); });
我是否需要创build自己的更新队列,首先从服务器中检索最新的文档,将文档合并在一起然后保存。 或者这是由mongodb处理的。
另外,是否有一个简单的方法,如更新,将旧的对象与新的对象,并保存?
谢谢。
http://mongoosejs.com/docs/api.html#document_Document-update
每个文档都有一个可用的update
方法。 希望有所帮助。
我这样做:
.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 )
_.merge
方法可以和一个警告一起使用:你不能合并一个mongoose文档,它必须是一个普通的对象,或者用.lean()
find,或者用.toObject()
Model.update({ _id: doc._id }, { $set: _.merge(doc.toObject(), { stuff: { hello: 'world' } }) })