所以我有一个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 或轻便摩托车或其他方式运行控制台命令吗?
谢谢