请教:mongodb帖子类表设计
本文介绍了请教:mongodb帖子类表设计的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
1.帖子有内容有回复,如果在mongodb里只用1个表的话,可以设计成这样
{
title:'巴拉巴拉',
content:'巴拉巴拉',
comments:[
{
user:123,//用户123的回复
content:'123'
},
{
user:456,//用户456的回复
content:'456'
}
]
}
这样的设计的话,如何修改 user:456 里的content?
1)是否用类似数组下标的方式?如:comments[1].content?如何写?
解决方案
如果你已经知道了{user: 456}
的下标,可以用数组下标的方式改:
db.coll.update({...}, {$set: {"comments.1.content": "567"}})
或者根据查询条件:
db.coll.update({"comments.user": 456}, {$set: {"comments.$.content": 567}})
其中$
代表匹配上的数组元素。但这种方式只会修改第一个匹配数组元素。所以要注意你的条件必须要精确匹配到你想改的那个元素。以你的数据为例,如果这个用户评论过2次,这样写就有问题了。
这篇关于请教:mongodb帖子类表设计的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文