请教:mongodb帖子类表设计
天蓬老师
天蓬老师 2017-05-02 09:21:46
0
1
521

1.帖子有内容有回复,如果在mongodb里只用1个表的话,可以设计成这样

{ title:'巴拉巴拉', content:'巴拉巴拉', comments:[ { user:123,//用户123的回复 content:'123' }, { user:456,//用户456的回复 content:'456' } ] }

这样的设计的话,如何修改 user:456 里的content?

1)是否用类似数组下标的方式?如:comments[1].content?如何写?
天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复 (1)
过去多啦不再A梦

如果你已经知道了{user: 456}的下标,可以用数组下标的方式改:

db.coll.update({...}, {$set: {"comments.1.content": "567"}})

或者根据查询条件:

db.coll.update({"comments.user": 456}, {$set: {"comments.$.content": 567}})

其中$代表匹配上的数组元素。但这种方式只会修改第一个匹配数组元素。所以要注意你的条件必须要精确匹配到你想改的那个元素。以你的数据为例,如果这个用户评论过2次,这样写就有问题了。

    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责声明 Sitemap
    PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!