首页 > 解决方案 > MongoDB 试图通过 id 来处理两个表 - 无法做到这一点

问题描述

我的数据库中有两个表。

teams桌子:

[
  {
    "users": [
      { "id": '5f9971e6f4f60959c0668896', "role": 'admin' },
      { "id": '5fb11570ece5672ba95850ee', "role": 'read' }
    ],
    "_id": '5fb0f993795d1634d4e486dc',
    "name": 'team1'
  },
  {
    "users": [
      { "id": '5fb11570ece5672ba95850ee', "role": 'admin' }
    ],
    "_id": "5fb0f993795d1634d4e48fed",
    "name": 'team2'
   }
]

users桌子:

[
 {
  "_id" : ObjectId("5f9971e6f4f60959c0668896"),
    "firstname" : "foo",
    "lastname" : "bar"
  },
  {
  "_id" : ObjectId("5fb11570ece5672ba95850ee"),
    "firstname" : "hey",
    "lastname" : "you"
  },
  {
  "_id" : ObjectId("5fb11570ece5672ba95grs0"),
    "firstname" : "12",
    "lastname" : "34"
  }
]

我想得到的是:

{
 users: 
  [
    { id: '5f9971e6f4f60959c0668896',firstname: "foo",lastname: "bar", role: 'admin' },
    { id: '5fb11570ece5672ba95850ee',firstname: "hey",lastname: "you", role: 'read' }
  ],
  _id: 5fb0f993795d1634d4e486dc,
  name: 'team1'
}

我试图解决这个一周,但我没有找到解决方案。

Teams.aggregate([
            {
              $lookup: {
                from: "users",
                localField: "_id",
                foreignField: "users.id",
                as: "users",
              },
            },
          ]).then((data) => {
            console.log("data", data);
          });

tnx 寻求帮助

标签: javascriptnode.jsmongodb

解决方案


您的团队集合 users.id 也需要是 ObjectId ,而不是字符串 ... ,或者您需要将用户集合 _id 更改为字符串 ...


推荐阅读