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()实现三表关联的方法(两种),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志