我在使用 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 值。
再次感谢!