MongoDB,NodeJS:使用新成员更新嵌入式文档

时间:2015-05-27 09:49:21

标签: json node.js facebook mongodb mongodb-query

使用: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"但是,在更新中,我不知道哪一个以及如何以编程方式将参数传递给它。

1 个答案:

答案 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不会对该数组执行任何操作。