MongoDB查询以从位于数组中的文档中检索特定值

时间:2018-10-25 13:39:26

标签: arrays json database mongodb

我正在尝试使用mongodb在文档中进行请求。

在本文档中

{
    "_id" : ObjectId("5bd19a92da24674fdabd26b6"),
    "search" : "try",
    "name" : "try",
    "email" : "yes@gmail.com",
    "password" : "$2a$10$YIRuApqDy/L8HU7R1k2SB.aC2hqH8xFDbl3/muF7PsoN6/SGzsH4q",
    "color" : 0,
    "profil" : "",
    "banner" : "",
    "desc" : "",
    "date" : 45587899,
    "friend" : [
            {
                    "id" : ObjectId("5bcee588ae409f434d35c76c")
            }
    ],
    "groupes" : [ ]
}

我希望仅在朋友中获取ID,而不是在我尝试使用此方法的情况下,在朋友中仅获取所有ID:

db.users.find({$and:[{"friend.id":"ObjectId(5bcee588ae409f434d35c76c)"},{"search":"try"}]})

它不起作用,我没有结果。

谢谢您的帮助。

2 个答案:

答案 0 :(得分:1)

我不是100%肯定会正确理解您的问题。您应该可以通过以下查询来查询描述的文档:

find(
  /* query by 'search' and the specific friend-id */
  {'friend.id': ObjectId("5bcee588ae409f434d35c76c"), search: 'try'}, 

  /* return only that 'friend' element which matches the queried 'friend-id' */
  {_id:0, friend:{$elemMatch:{id:ObjectId("5bcee588ae409f434d35c76c")}}}
)

您得到以下结果:

{
    "friend" : [ 
        {
            "id" : ObjectId("5bcee588ae409f434d35c76c")
        }
    ]
}

答案 1 :(得分:-1)

db.users.find({
    friend: {
        $elemMatch: {
            id: ObjectId("5bcee588ae409f434d35c76c")
        }
    },
    search: 'try'
})