2016-08-21 24 views
1

「スルー」テーブルと多対多リレーションシップを持つ2つのテーブルから情報を照会しているケースがあります。クエリを作成すると、テーブル結合参照として「スルー」テーブルを使用せず、両方のテーブル属性で出力レコードを受け取ることで正しくクエリを実行しているように見えますが、結合テーブルのフィールドプロパティにアクセスできません。ここに出力された値があります。Sequelize多対多リレーションシップとオブジェクトへのアクセス

ここ
.get(function(req, res){ 
models.User.find({ 
       where: { 
        organizationId: organization.organizationId 
       }, attributes: ['email', 'firstName', 'lastName'], 
       include: [{ 
        model: models.Team, 
        attributes: ['teamName'] 
       }] 
      }); 
     }).then(function(currentUsers){ 
      res.jsonp(currentUsers); 
console.log(currentUsers); 
     }); 

は私が私の見解でTEAMNAMEにアクセスしようとしていた方法です:{{currentUsers.teams.teamName}}、値を返すのではなく、ここで

{"fullNameSlug":"Tester Test","email":"[email protected]","firstName":"Tester","lastName":"Test","teams":[{"teamName":"Sales","member":{"memberId":1,"memberEmail":"[email protected]","organizationId":1,"teamId":1,"userId":1,"created_at":"2016-08-21T21:15:19.000Z","updated_at":"2016-08-21T22:00:32.000Z","organization_id":1,"team_id":1,"user_id":1}}]} 

は私のクエリと私はデータを設定しています方法です {{currentUsers.email}}は正しいユーザーのメールを返します。

ユーザー表:

module.exports = function(sequelize, DataTypes) { 

var User = sequelize.define('user', { 
    userId: { 
     type: DataTypes.INTEGER, 
     field:'user_id', 
     autoIncrement: true, 
     primaryKey: true 
    }, 
    firstName: { 
     type: DataTypes.STRING, 
     field: 'first_name' 
    }, 
    lastName: { 
     type: DataTypes.STRING, 
     field: 'last_name' 
    }, 
    email: { 
     type: DataTypes.STRING, 
     isEmail: true, 
     unique: true, 
     set: function(val) { 
      this.setDataValue('email', val.toLowerCase()); 
     } 
    }, 
    password: DataTypes.STRING, 
    organizationId: { 
     type: DataTypes.INTEGER, 
     field: 'organization_id', 
     allowNull: true 
    } 
}, { 
    underscored: true, 
    freezeTableName: true, 
    }, 
    classMethods: { 
     associate: function(db) { 
      User.belongsToMany(db.Organization, { through: 'member', foreignKey: 'user_id'}), 
      User.belongsToMany(db.Team, { through: 'member', foreignKey: 'user_id'}) 
     } 
}); 
    return User; 
} 

チーム表:

module.exports = function(sequelize, DataTypes) { 

var Team = sequelize.define('team', { 
    teamId: { 
     type: DataTypes.INTEGER, 
     field: 'team_id', 
     autoIncrement: true, 
     primaryKey: true, 
     notNull: true 
    }, 
    teamName: { 
     type: DataTypes.STRING, 
     field: 'team_name' 
    }, 
    organizationId: { 
     type: DataTypes.INTEGER, 
     field: 'organization_id' 
    }, 
},{ 
    underscored: true, 
    freezeTableName: true, 
    classMethods: { 
     associate: function(db) { 
      Team.belongsToMany(db.User, { through: 'member', foreignKey: 'team_id' }); 
     }, 
    } 
}); 
    return Team; 
} 

メンバー表:

module.exports = function(sequelize, DataTypes) { 

var Member = sequelize.define('member', { 
    memberId: { 
     type: DataTypes.INTEGER, 
     field: 'member_id', 
     autoIncrement: true, 
     primaryKey: true 
    }, 
    memberEmail: { 
     type: DataTypes.STRING, 
     field: 'member_email', 
     isEmail: true, 
     unique: true 
    }, 
    organizationId: { 
     type: DataTypes.INTEGER, 
     field: 'organization_id', 
     allowNull: true 
    }, 
    teamId: { 
     type: DataTypes.INTEGER, 
     field: 'team_id', 
     allowNull: true 
    }, 
    userId: { 
     type: DataTypes.INTEGER, 
     field: 'user_id', 
     allowNull: true 
    } 
},{ 
    underscored: true, 
    freezeTableName: true, 
}); 
    return Member; 
} 

出力されたSQL:

SELECT `user`.*, `teams`.`team_id` AS `teams.teamId`, `teams`.`team_name` AS `teams.teamName`, `teams.member`.`member_id` AS `teams.member.memberId`, `teams.member`.`member_email` AS `teams.member.memberEmail`, `teams.member`.`organization_id` AS `teams.member.organizationId`, `teams.member`.`team_id` AS `teams.member.teamId`, `teams.member`.`user_id` AS `teams.member.userId`, `teams.member`.`created_at` AS `teams.member.created_at`, `teams.member`.`updated_at` AS `teams.member.updated_at`, `teams.member`.`organization_id` AS `teams.member.organization_id`, `teams.member`.`team_id` AS `teams.member.team_id`, `teams.member`.`user_id` AS `teams.member.user_id` FROM (SELECT `user`.`user_id` AS `userId`, `user`.`email`, `user`.`first_name` AS `firstName`, `user`.`last_name` AS `lastName` FROM `user` AS `user` WHERE `user`.`organization_id` = 1 LIMIT 1) AS `user` LEFT OUTER JOIN (`member` AS `teams.member` INNER JOIN `team` AS `teams` ON `teams`.`team_id` = `teams.member`.`team_id`) ON `user`.`userId` = `teams.member`.`user_id`; 

答えて

1

はあなたの関係を考えてみましょう、ユーザーは予想通り多くのチーム(チームオブジェクトの配列)をユーザに返す多くのチームトラフテーブルのメンバーとあなたのクエリを持っています。特定のチームをキーで取得するにはuser.teams[0].teamNameを使用するか、この配列内のオブジェクトをループする

関連する問題