如何在 laravel 中检索用户时急切加载?
Posted
技术标签:
【中文标题】如何在 laravel 中检索用户时急切加载?【英文标题】:How to eager load while retrieving users in laravel? 【发布时间】:2021-02-09 04:16:28 【问题描述】:假设我有 20 个用户,他们的角色是管理员、代理、经理和客户。在获取所有 20 个用户时,它触发了 21 个查询。我想急切地加载它。
获取所有用户时从 20 个触发的查询中查询的示例。
select `roles`.*, `model_has_roles`.`model_id` as `pivot_model_id`, `model_has_roles`.`role_id` as `pivot_role_id`, `model_has_roles`.`model_type` as `pivot_model_type` from `roles` inner join `model_has_roles` on `roles`.`id` = `model_has_roles`.`role_id` where `model_has_roles`.`model_id` = 1 and `model_has_roles`.`model_type` = 'App\Models\User'
这是我的控制器
public function index()
$data=User::get();
$info=Role::get();
$permi=Permission::get();
return view('admin.role',['userinfo'=>$data, 'roleinfo'=>$info,'per'=>$permi]);
这是我的刀片视图,我在其中检索了用户的信息并为该用户分配了角色
@foreach ($userinfo as $users)
<tr>
<th scope="row"> $users->id </th>
<td> $users->name </td>
<td> $users->email </td>
<td>
@if(!empty($users->getRoleNames()))
@foreach($users->getRoleNames() as $v)
<label class="badge badge-success"> $v </label>
@endforeach
@endif
</td>
</tr>
@endforeach
我知道我必须在 User 模型中显示一个关系,但我对如何显示一个关系感到困惑。此外,我使用了 spatie 包和身份验证,因此我的用户模型正在扩展 Authenticatable。我对该怎么做感到非常困惑。
【问题讨论】:
这能回答你的问题吗? Spatie Laravel permissions eager loaded 这个问题之前有人问过,有很多参考可以参考。你可以得到一个快速的帮助。如果那无济于事,请尝试留下更多详细信息的评论。 ***.com/questions/60926026/…. 感谢 KamleshPaul 和 JaswinderSingh 很有帮助 【参考方案1】:在用户模型中,我展示了 belongsToMany
与 model_has_roles
表的关系
function role()
return $this->belongsToMany(Role::Class, 'model_has_roles','model_id','role_id');
然后在我的控制器中
public function index()
$data=User::with('role')->get();
$info=Role::get();
$permi=Permission::get();
return view('admin.role',['userinfo'=>$data, 'roleinfo'=>$info,'per'=>$permi]);
然后在我的刀片视图中,我在为分配的用户获取角色时做了一些小改动
@foreach ($userinfo as $users)
<tr>
<th scope="row"> $users->id </th>
<td> $users->name </td>
<td> $users->email </td>
<td>
@if(!empty($users->role))
@foreach($users->role as $v)
<label class="badge badge-success"> $v->name </label>
@endforeach
@endif
</td>
</tr>
@endforeach
然后这减少了我的查询计数。感谢所有对此感兴趣的人。
【讨论】:
以上是关于如何在 laravel 中检索用户时急切加载?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Laravel 中为 ORM 急切加载添加多个键约束?