首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在MongoDB中查询被引用的对象?

如何在MongoDB中查询被引用的对象?
EN

Stack Overflow用户
提问于 2012-03-09 01:19:38
回答 3查看 72.6K关注 0票数 51

我的Mongo数据库中有两个集合,Foo包含对一个或多个Bar的引用:

代码语言:javascript
复制
Foo: { 
  prop1: true,
  prop2: true,
  bars: [
     {
     "$ref": "Bar",
     "$id": ObjectId("blahblahblah")
     }
  ]
}

Bar: {
   testprop: true
}

我想要的是找到至少有一个Bar将其testprop设置为true的所有Foo。我试过这个命令,但它没有返回任何结果:

代码语言:javascript
复制
db.Foo.find({ "bars.testprop" : { "$in": [ true ] } })

有什么想法吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-09-14 02:24:06

现在你可以在Mongo3.2中使用$lookup完成这项工作

$lookup有四个参数

from:指定要执行联接的同一数据库中的集合。不能对from集合进行分片。

localField:指定从文档输入到$lookup阶段的字段。$lookup对来自from集合的文档中的localField与foreignField执行相等匹配。

foreignField:指定from集合中文档的字段。

as:指定要添加到输入文档的新数组字段的名称。新的数组字段包含来自from集合的匹配文档。

代码语言:javascript
复制
db.Foo.aggregate(
  {$unwind: "$bars"},
  {$lookup: {
    from:"bar",
    localField: "bars",
    foreignField: "_id",
    as: "bar"

   }},
   {$match: {
    "bar.testprop": true
   }}
)
票数 83
EN

Stack Overflow用户

发布于 2012-03-09 01:27:52

您不能。请参阅http://www.mongodb.org/display/DOCS/Database+References

您必须在客户端完成此操作。

票数 21
EN

Stack Overflow用户

发布于 2016-01-11 13:44:11

好吧..。您可以使用testprop: true查询Bar模型以获得所有文档的_id,然后在Foo模型上执行查找$in并使用从第一个查询中获得的bars数组填充这些_id。:P

也许这可以算作“在客户端”:P只是一种想法。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9621928

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档