使用Laravel Eloquent中的关系与桥牌表

时间:2016-01-02 20:12:13

标签: mysql laravel laravel-4 eloquent laravel-4.2

我有一个处理用户信息的应用程序,我们收集的其中一个数据是他们参加的学校。我们有一个User对象,School对象和一个UserSchool对象。

这是user_schools表:

user_id (int),school_id (int)

以下记录为例:

100, 20
200, 500
200, 10
300, 10

我试图让所有学校都为当前用户(比如用户200)。这是我的UserSchool对象:

class UserSchool extends Model
{
    var $table = 'user_schools';

    function user() {
        return $this->belongsTo('User');
    }

    function school() {
        return$this->belongsTo('School');
    }

}

User我定义了以下关系:

public function schools()
    {
        return $this->hasManyThrough('School', 'UserSchool');
    }

    public function userSchools()
    {
        return $this->hasMany('UserSchool');
    }

当我var_dump($user->schools)时,我没有得到任何结果,即使我知道它应该返回多个School。我究竟做错了什么?我确定之前一定要问过,但我不知道这种中间类型关系的实际用语是什么(桥接表?数据透视表?)。

编辑:无论哪种方式,我看过的大多数例子都没有用。我也试过了:

public function schools()
    {
        return $this->hasManyThrough('School', 'UserSchool',  'school_id');
    }

1 个答案:

答案 0 :(得分:4)

事实上,您不需要在此处拥有UserSchool对象

对于User模型,您可以使用创建以下关系:

public function schools() 
{
   return $this->belongsToMany(School::class, 'user_schools');
}

现在,您可以使用以下内容获得用户学校:

$user = User::find(1);
foreach ($user->schools as $school) 
{
   echo $school->name;
}

这是标准many to many relationship