db.app_examine_interception.aggregate(
[
{
$match:{
$or:[{'error_no':'105'},{'error_no':'103'}]
}
},
{
$lookup:{
from:"project",
localField:'publish_id',
foreignField:'_id',
as:"out_put_docs"
}
},
{
$project:{'out_projectID':1,'out_put_docs.project_name':1, "count": {"$sum": 1}}
}
]
)
$lookup
操作是一个需要四个参数的对象,该对象的属性解释如下:
(相当于sql中的join)
- localField:在输入文档中的查找字段,这里是:app_examine_interception集合中的publish_id字段。
- from:需要连接的集合,这里是:project
- foreignField:需要在from集合中查找的字段
- as:输出集合的名字,自定义
思路:
先使用$match
确定待查询数据的范围
再使用$lookup
联结另一个表,确定查询字段
最后使用$project
选择需要输出的字段
参考资料:
详解MongoDB中的多表关联查询($lookup)
https://www.cnblogs.com/xuliuzai/p/10055535.html
mongodb多表联查
https://blog.youkuaiyun.com/eric_to/article/details/90093806
$lookup使用
https://www.xttblog.com/?p=3787
【Mongodb】aggregate限制返回字段
https://blog.youkuaiyun.com/thewindkee/article/details/54671110
MongoDB查询指定字段(field)返回指定字段的方法
https://www.cnblogs.com/duhuo/p/4336122.html
mongoDB进行分组操作
https://www.cnblogs.com/qiyc/p/9053909.html