在mongodb中查找和更新多级嵌套查询

时间:2015-08-04 10:02:02

标签: node.js mongodb mongodb-query monk

我的文档结构如下

{
    "_id": {
        "$oid": "55ae24016fb73f6ac7c2d640"
    },
    "Name": "some name",
    "District": "some district",
    "Stories": [
        {
            "userId": "105304831528398207103",
            "story": "some story",
            "Likes": ["user id 1" ..... ],
            "_id": {
                "$oid": "55c055af1875b0002572cf94"
            }
        }
    ]
}

现在,当用户喜欢某个故事时,我想将他的用户ID添加到数组喜欢

我尝试了以下代码

router.post("/NewStoryLike", function (req, res) {
    var mongo = require('mongodb');
    var db = require('monk');
    var ObjectID = mongo.ObjectID;
    req.db.get('clnTemple').findAndModify({
        query: { "_id": ObjectID(req.body.postId) ,"Stories._id": ObjectID(req.body.storyId) },
        update: { $addToSet: { Likes: req.body.userId } },
        upsert: true
    });
    res.send("Like Added");
});

它没有抛出任何错误,但它没有向喜欢的数组添加用户ID,而是在顶级添加了一个Likes,即它添加到帖子级别

应该做出哪些改变?

1 个答案:

答案 0 :(得分:3)

因此使用嵌套数组对于设计来说是一个坏主意。这是因为MongoDB中对数组更新的限制。正如positional $ update运营商的文档中所述:

  

嵌套数组

     

位置$运算符不能用于遍历多个数组的查询,例如遍历嵌套在其他数组中的数组的查询,因为替换了$占位符是单一值

然而,只有$push|$addToSet才能完全正常,其中您实际匹配的唯一数组 外部数组,因此"首先"数组元素匹配。只要你的命名正确:

req.db.get('clnTemple').findAndModify({
    { 
        "_id": req.body.postId ,
        "Stories._id": ObjectID(req.body.storyId),
    },
    { "$addToSet": { "Stories.$.Likes": req.body.userId } },
    { "new": true },
    function(err,doc) {
       // updted doc in here
    }
);

除此之外你不应该真正使用嵌套数组,这样可以正常工作,因为它只是附加到"内部"匹配"外部"的数组阵列。

作为个人喜好,我建模"喜欢"更加不同,更加可靠。但这是另一个问题。