如何在 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】:

在用户模型中,我展示了 belongsToManymodel_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 5.1通过急切加载返回连接字段

如何在 Laravel 中为 ORM 急切加载添加多个键约束?

Laravel 在急切加载时使用 Eloquent 选择特定列

Laravel 动态关系 - 在急切加载时访问模型属性

Laravel 急切加载限制

如何从急切加载中指定我们想要的列