3

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

在我的猫鼬模式(“正在发生”)中,我声明了一个名为“预期”的 ObjecId 数组,供 .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 值。

再次感谢!

4

1 回答 1

1

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

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

感谢您澄清我的返回值 JohnnyHK。

于 2013-06-28T18:31:59.730 回答