使用:MongoDB和native nodeJS mongoDB驱动程序。
我试图解析来自fb graph api的所有数据,将其发送到我的API,然后将其保存到我的数据库中。
我服务器中的PUT处理:
//Update user's data
app.put('/api/users/:fbuser_id/:category', function(req, res) {
var body = JSON.stringify(req.body);
var rep = /"data":/;
body = body.replace(rep, '"' + req.params.category + '"' + ':');
req.body = JSON.parse(body);
db.fbusers.update({
id: req.params.fbuser_id
}, {
$set: req.body
}, {
safe: true,
multi: false
},
function(e, result) {
if (e) return next(e)
res.send((result === 1) ? {
msg: 'success'
} : {
msg: 'error'
})
});
});
我一次发送25个元素,此代码只是覆盖而不是更新文档。
数据我发送到API:
{
"data": [
{
"category": "App page",
"name": "SoundCloud",
"id": "7919071058",
"created_time": "2013-09-16T18:16:59+0000"
},
{
...and so on
}
]
}
基本上我的API更改"数据"密钥从发送的json到类别名称,f.e。: PUT到/ api / users / 000 / likes会改变"数据"关键是"喜欢":
{
"likes": [
{
"category": "App page",
"name": "SoundCloud",
"id": "7919071058",
"created_time": "2013-09-16T18:16:59+0000"
},
{
...and so on
}
]
}
然后将此JSON放入db。
mongodb中的层次结构:
{
"_id": ObjectID("556584c8e908f0042836edce"),
"id": "0000000000000",
"email": "XXXX@gmail.com",
"first_name": "XXXXXXXX",
"gender": "male",
"last_name": "XXXXXXXXXX",
"link": "https://www.facebook.com/app_scoped_user_id/0000000000000/",
"locale": "en_US",
"name": "XXXXXXXXXX XXXXXXXXXX",
"timezone": 3,
"updated_time": "2015-05-26T18:11:59+0000",
"verified": true,
"likes": [
{
"category": "App page",
"name": "SoundCloud",
"id": "7919071058",
"created_time": "2013-09-16T18:16:59+0000"
},
{
"category": "App page",
"name": "SoundCloud",
"id": "7919071058",
"created_time": "2013-09-16T18:16:59+0000"
},
{
....and so on
}
]
}
所以问题是我的api用新发送的数据覆盖了字段(在这种情况下"喜欢"),而不是将其附加到现有的数据文档。
我很确定我应该使用其他参数而不是" $ put"但是,在更新中,我不知道哪一个以及如何以编程方式将参数传递给它。
答案 0 :(得分:0)
使用$push with the $each modifier将多个值附加到数组字段。
var newLikes = [
{/* new item here */},
{/* new item here */},
{/* new item here */},
];
db.fbusers.update(
{ _id: req.params.fbuser_id },
{ $push: { likes: { $each: newLikes } } }
);
另请参阅$addToSet运算符,除非值已存在,否则它会向数组添加值,在这种情况下,$ addToSet不会对该数组执行任何操作。