您好,匿名用户
随意问技术百科期待您的加入

mongodb如何进行子查询

0 投票

用户collection,我是这么设计的:

User {
    uid: xx,
    name: xxx,
    description: xxxx,
    follow: ["uid1","uid2","uid3",...]
}

为了列出某个用户follow的所有人列表,我该如何写查询语句呢?

<uid1, name1, description1>
<uid2, name2, description2>
...
用户头像 提问 2012年 12月1日 @ Elise 上等兵 (273 威望)
分享到:

1个回答

0 投票
 
最佳答案

不要仅仅把mongodb当做一个schemeless的sql数据库,mongodb是没有子查询和跨表查询这个概念的。

按照你的描述,如果你想要获取某个用户follow的所有人的详细信息列表,一种做法是把这些用户的所有信息都存到User里面:

User {
    uid: xx,
    name: xxx,
    description: xxxx,
    follow: ["uid1": {'name': 'xxx', 'description': 'desc1'},"uid2": {'name': 'zzz', 'description': 'desc2'},...]
}

或者你使用二次查询,在代码里面再查一次

db.User.find({'uid':{'$in': [uid1, uid2, uid3]}});
用户头像 回复 2012年 12月1日 @ Rengar 上等兵 (236 威望)
选中 2012年 12月1日 @Elise
提一个问题:

相关问题

0 投票
1 回复 44 阅读
0 投票
1 回复 80 阅读
0 投票
1 回复 44 阅读
用户头像 提问 2012年 12月1日 @ Zyra 上等兵 (289 威望)
0 投票
1 回复 52 阅读
用户头像 提问 2012年 12月1日 @ Talon 上等兵 (294 威望)
0 投票
0 回复 24 阅读

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...