query - mongodb如何進行子查詢
怪我咯
怪我咯 2017-04-21 11:16:39
0
1
775

用戶collection,我是這麼設計的:

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

為了列出某個用戶follow的所有人列表,我該如何寫查詢語句呢?

<uid1, name1, description1>
<uid2, name2, description2>
...
怪我咯
怪我咯

走同样的路,发现不同的人生

全部回覆(1)
黄舟

不要只把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]}});
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板