1

所以我有一个Groups看起来像这样的集合

[
    {
        \"_id\": \"51bdff3968c7c4dd30000003\",
        \"members\": [
            {
                \"id\": \"51bdedef68c7c4bc7c000001\",
                \"role\": \"admin\"
            },
            {
                \"id\": \"51be0d4568c7c473ef000007\",
                \"role\": \"user\"
            }
        ],
        \"name\": \"tetsing2\"
    },
    {
        \"_id\": \"51bdf97868c7c46604000002\",
        \"members\": [
            {
                \"id\": \"51be12ae68c7c4dcce000001\",
                \"role\": \"user\"
            },
            {
                \"id\": \"51be12db68c7c45e08000002\",
                \"role\": \"user\"
            }
        ],
        \"name\": \"ds\"
    }
]" 

我只是获取成员数组中 id 等于的对象51be12db68c7c45e08000002

我可以使用此命令在控制台 mongo 客户端中执行此操作

db.groups.find({ "members.id": ObjectId("51be12db68c7c45e08000002") })

它只返回一个名为'ds'

但是,在 Rails 中使用 Mongoid 时,当我尝试类似这样的命令时:

@groups = Group.where(' { "members.id": "'+current_user.id+'"}')

我拿回了两个对象。

我查看了文档,但是有谁知道如何通过 Mongoid 实现这一点,或者我可以通过 Monogoid 或轻便摩托车或其他方式运行控制台命令吗?

谢谢

4

1 回答 1

1
Group.where( :"members.id" => current_user.id )
于 2013-06-17T01:16:07.253 回答