我的文档结构如下
{
"_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,即它添加到帖子级别
应该做出哪些改变?
答案 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
}
);
除此之外你不应该真正使用嵌套数组,这样可以正常工作,因为它只是附加到"内部"匹配"外部"的数组阵列。
作为个人喜好,我建模"喜欢"更加不同,更加可靠。但这是另一个问题。