此问题扩展了Laravel文档中提供的示例Eloquent : Working With Pivot Tables。
我在应用程序中需要以下关系:
User belongsToMany Role
Role belongsToMany Task
User belongsToMany Task
User belongsToManyThrough Role->Task (Task through Role)
Task
或直接与Role
相关联。 我不清楚的部分是我需要在模型中设置这些部分,以便我可以使用诸如急切加载之类的东西来获取:
例如,为了启用所有这些关系,x和y应该在下面是什么?
class User extends Eloquent {
public function tasks()
{
return x;
}
}
class Task extends Eloquent {
public function users()
{
return y;
}
}
答案 0 :(得分:0)
我曾经遇到过belongsToManyThrough的问题,我用这段代码解决了它:
public function Roles()
{
$task_ids = DB::table('tasks_users')->where('user_id', $this->id)->lists('task_id');
$role_ids = DB::table('tasks_roles')->whereIn('task_id', $task_ids )->lists('role_id');
return Roles::whereIn('id', $role_ids)->get();
}
我知道它没有使用函数belongsToManyThrough,它不是最优化的方式,但它正在工作。 :)