Mongoose:在Orphan Id中使用带有ObjectIds结果的addToSet

时间:2013-06-28 17:44:39

标签: node.js mongodb mongoose

我在使用mongoDB的$ addToSet到一个充满ObjectIds的数组时遇到了一个相当有趣的问题。

在我的mongoose模式中(" Happening"),我声明了一个名为" expect"的ObjecIds数组,供.populate()使用。

expected: [{type: Schema.Types.ObjectId, ref: "User" }]

...在我使用它的任何地方都很好用。到目前为止一切都很好。

然后我尝试使用$ addToSet更新Happening.expected数组,如下所示:

http://docs.mongodb.org/manual/reference/operator/addToSet/
像这样:

app.get("/happening/yamobethere/:id", ensureLoggedIn("/login"),
    function (req, res) {

    // userId is the mongo ObjectId of the user record
    var userId = req.session.user.id, 
        eventId = req.params.id;

    models.Happening.update(
        {_id: eventId}, {
            $addToSet: {expected: userId}
        },
        function(err, updated){
            if (err) {
                res.json({"error": err});
            }
            res.json({"updated": updated});
    });
});

......总是产生:

{updated: 1}

现在,文档引导我期待我传入的实际userId,所以" 1"有点奇怪。我预计它会失败,并且鉴于接下来会发生的奇怪现象,它似乎是某种类型的mongodb错误,它会将它作为结果反馈给我。

奇怪的是,当我检查我的数据库时,我发现确实添加了一个新的ObjectId:而不是我传入的那个。

"expected" : [
        ObjectId("51cb18623ade2b9f1e000004"), 
        ObjectId("51cdb7c12f0e58bdb3000001")
    ],

变为

"expected" : [
        ObjectId("51cb18623ade2b9f1e000004"), 
        ObjectId("51cdb7c12f0e58bdb3000001"), 
        ObjectId("51cdb80e09612bfab3000002")  
    ],

新的ObjectId没有出现在我的任何集合中。它似乎是一个孤儿,但我是一个mongo noob,所以我可能充满了堆肥。

我确实尝试将userId强制转换为ObjectId:

$addToSet: {expected: mongoose.Types.ObjectId.fromString(userId)}

但是没有改变,实际上不应该是必要的,因为架构应该处理它。

我真的不愿意下载整个对象,将值附加到"期望"数组,然后发回整个schmear进行更新。

任何帮助表示赞赏,伙计们。谢谢!

更新

一位同事提出了以下技巧:

    var addMe = {$addToSet: {expected: userId}};

    models.Happening.findByIdAndUpdate(eventId, addMe, function(err, me) {
        if (err) {
            return json(err);
        }
        res.json(200, me);
    });

...这有点改进,因为它实际上会返回一个对象供我检查。不幸的是,它也会导致孤立的ObjecIds出现在数组中,而不是我指定的现有userId值。

再次感谢!

1 个答案:

答案 0 :(得分:0)

看来我的护照策略是通过来自oauth的数据返回被拒绝的尝试在db中创建新用户的ObjectID。所以,代码很好,我的数据很垃圾。

永远不要相信任何东西,并准备好看起来像一个布布。 : - )

感谢您对我的回归价值JohnnyHK的澄清。