我有一个列表和用户之间的多对多关系。 这是List型号:Laravel 5 - 雄辩:更简单的方法来过滤多对多的关系
class ListModel extends Model
{
protected $table = "lists";
public function users()
{
return $this->belongsToMany('App\Models\User', 'list_user', 'list_id', 'user_id')->withTimestamps();
}
}
这是用户模式:
class User extends Authenticatable
{
public function lists()
{
return $this->hasMany('App\Models\ListModel');
}
}
在列表页,我需要把所有属于登录用户的列表。我发现的唯一解决方案是:
$user = \Auth::user()->id;
$all_lists = ListModel::whereHas('users', function ($query) use ($user) {
$query->where('user_id', $user);
})->active()->get();
有没有更简单的方法来实现相同的结果?
发现这个有用https://laracasts.com/discuss/channels/laravel/how-to-eager-load-a-relation-on-authuser – Gayan