首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MongoDB集群:与其他集合不同

MongoDB集群:与其他集合不同
EN

Stack Overflow用户
提问于 2021-11-04 11:17:33
回答 1查看 26关注 0票数 0

我有两个收藏品:

员工

  • _id
  • 办公室
  • jobTitle

offices

  • _id
  • 城市

我正试图收到一份列有敬重办公室雇员职称的所有办公地点的名单。

最终结果将如下所示:

代码语言:javascript
复制
[{
 _id: ObjectId('6086f617cc0824cc4ce7c9f0'),
 city: "Berlin",
 jobTitles: ['SOFTWARE ENGINEER', 'CEO', 'CFO']
}, {
 _id: ObjectId('60c08d36f925f3083488ea79'),
 city: "Prague",
 jobTitles: ['UX DESIGNER', 'BUSINESS ANALYST']
}]

这是我尝试过的聚合,但没有成功:

代码语言:javascript
复制
db.offices.aggregate([{
 $lookup: {
  from: 'employees',
  localField: '_id',
  foreignField: 'office',
  as: 'jobTitles',
  project: [{
    $group: { _id: '$jobTitle'}
  }]
 }
}]);

一个办公室可以有数千名员工,所以我试图使查询尽可能高效。

谢谢你的想法!)

EN

回答 1

Stack Overflow用户

发布于 2021-11-04 11:38:48

使用$lookup

代码语言:javascript
复制
db.offices.aggregate([
  {
    "$lookup": {
      "from": "employees",
      "localField": "_id",
      "foreignField": "office",
      "as": "jobTitles"
    }
  },
  {
    "$set": {
      "jobTitles": "$jobTitles.jobTitles"
    }
  },
  {
    "$unwind": "$jobTitles"
  },
  {
    "$group": {
      "_id": "$_id",
      "city": {
        "$first": "$city"
      },
      jobTitles: {
        $addToSet: "$jobTitles"
      }
    }
  }
])

蒙古操场

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

https://stackoverflow.com/questions/69838398

复制
相关文章

相似问题

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