我有一个模式的模型:
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处理的。
此外,是否有一个简单的方法,如更新,将旧对象与新对象合并,并保存?
谢谢。
答案 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'
}
})
})