使用 Laravel Eloquent 中的关系与桥梁 table
Using relationships in Laravel Eloquent with bridge table
我有一个处理用户信息的应用程序,我们收集的数据之一是他们就读的学校。我们有一个 User
对象、School
对象和一个 UserSchool
对象。
这是user_schools table:
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
。我究竟做错了什么?我确定之前一定有人问过这个问题,但我不知道这种中间类型关系的实际术语是什么(桥梁 table?枢轴 table?)。
编辑:无论哪种方式,我看过的大多数示例都没有用。我也试过:
public function schools()
{
return $this->hasManyThrough('School', 'UserSchool', 'school_id');
}
事实上,对于这种关系,您不需要UserSchool
对象
对于 User
模型,您可以使用创建以下关系:
public function schools()
{
return $this->belongsToMany(School::class, 'user_schools');
}
现在您可以使用类似这样的方式获取用户学校:
$user = User::find(1);
foreach ($user->schools as $school)
{
echo $school->name;
}
我有一个处理用户信息的应用程序,我们收集的数据之一是他们就读的学校。我们有一个 User
对象、School
对象和一个 UserSchool
对象。
这是user_schools table:
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
。我究竟做错了什么?我确定之前一定有人问过这个问题,但我不知道这种中间类型关系的实际术语是什么(桥梁 table?枢轴 table?)。
编辑:无论哪种方式,我看过的大多数示例都没有用。我也试过:
public function schools()
{
return $this->hasManyThrough('School', 'UserSchool', 'school_id');
}
事实上,对于这种关系,您不需要UserSchool
对象
对于 User
模型,您可以使用创建以下关系:
public function schools()
{
return $this->belongsToMany(School::class, 'user_schools');
}
现在您可以使用类似这样的方式获取用户学校:
$user = User::find(1);
foreach ($user->schools as $school)
{
echo $school->name;
}