Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)
背景:
现有group(组)和user(用户)两种实例。
一个group中可以拥有多个user,一个user也可以属于有多个group(多对多关系)
GroupUserRelation表用于绑定组合组员的关系(使用id绑定)
字段有id,group_id,user_id
现有User(用户)表,需要获取其所属的所有用户组的信息,需要使用hasMany()进行多表关联。
User.id=>GroupUserRelation.user_id GroupUserRelation.group_id=>Group.id
方法1
publicfunctiongetGroup() { return$this->hasMany(Group::className(),['id'=>'group_id']) ->viaTable(GroupUserRelation::tableName(),['user_id'=>'id']); }
方法2
publicfunctiongetGroup() { return$this->hasMany(Group::className(),['id'=>'group_id']) ->viaTable('groupUserRelation'); } publicfunctiongetGroupUserRelation() { return$this->hasMany(GroupUserRelation::tableName(),['user_id'=>'id']); }
以上所述是小编给大家介绍的Yii2hasOne(),hasMany()实现三表关联的方法(两种),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!