当前位置: 移动技术网 > IT编程>开发语言>PHP > Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)

Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)

2017年12月12日  | 移动技术网IT编程  | 我要评论

背景:

现有 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

public function getgroup()
{
  return $this->hasmany(group::classname(), ['id' => 'group_id'])
     ->viatable(groupuserrelation::tablename(), ['user_id' => 'id']);
}

方法2

public function getgroup()
{
  return $this->hasmany(group::classname(), ['id' => 'group_id'])
     ->viatable('groupuserrelation');
}
public function getgroupuserrelation()
{
  return $this->hasmany(groupuserrelation::tablename(), ['user_id' => 'id']);
}

以上所述是小编给大家介绍的yii2 hasone(), hasmany() 实现三表关联的方法(两种),希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网