Join across multiple junction tables with Sequelize

前端 未结 2 1016
灰色年华
灰色年华 2021-01-31 03:17

I have a database with three primary tables: users, teams, and folders joined by two junction tables, users_teams and t

2条回答
  •  猫巷女王i
    2021-01-31 04:15

    Assuming the following relations:

    User.belongsToMany(Team, { through: 'users_teams'});
    Team.belongsToMany(User, { through: 'users_teams'});
    
    Folder.belongsToMany(Team, { through: 'teams_folders'});
    Team.belongsToMany(Folder, { through: 'teams_folders'});
    

    You should be able to load everything in one go using nested includes:

    User.findAll({
      include: [
        {
          model: Team, 
          include: [
            Folder
          ]  
        }
      ]
    });
    

    You seem to be on the right track already with the example you have given in your post :). The only thing you need to change is instead of passing the User model directly in include, you pass an object with a model property and a further nested include property

提交回复
热议问题