我在使用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值。
再次感谢!
答案 0 :(得分:0)
看来我的护照策略是通过来自oauth的数据返回被拒绝的尝试在db中创建新用户的ObjectID。所以,代码很好,我的数据很垃圾。
永远不要相信任何东西,并准备好看起来像一个布布。 : - )
感谢您对我的回归价值JohnnyHK的澄清。