使用 Eloquent withCount () 来 count 对应关系的条数

Eloquent 有一个鲜为人知的函数叫 withCount():它可以帮助获取包括远程一对多关系在内的对象关联的记录条数。接下来看示例。

在我们的示例小项目中,我们有三个模型:UserPost 以及 Comment。所有的关联关系都可以用这三个模型来举例描述,先看 app/User.php 模型:

public function posts()
{
    return $this->hasMany(Post::class);
}

public function comments()
{
    return $this->hasManyThrough(Comment::class, Post::class);
}

现在,我们来尝试在页面上显示如下的表格 - 用户及他们的文章和评论的统计列表:

实现很简单,下面是控制器 UserController 的代码:

public function index()
{
    $users = User::withCount(['posts', 'comments'])->get();
    return view('users', compact('users'));
}

传递到 withCount() 方法的每一个参数,最终都会在模型实例中创建一个参数名添加了 _count  后缀的属性。因此,在上面的例子中,可以通过访问 $user->posts_count 和 $user->comments_count 属性来获取统计数值。

然后,在我们的视图文件中,我们有:

<table class="table">
    <thead>
        <tr>
            <th>User</th>
            <th class="text-center">Posts</th>
            <th class="text-center">Comments</th>
        </tr>
    </thead>
    <tbody>
        @foreach ($users as $user)
            <tr>
                <td>{{ $user->name }}</td>
                <td class="text-center">{{ $user->posts_count }}</td>
                <td class="text-center">{{ $user->comments_count }}</td>
            </tr>
        @endforeach
    </tbody>
</table>

注意, withCount() 既可以处理 hasMany() 关系,也可以处理hasManyThrough().的第二级深度。

不仅如此,我们甚至可以在使用 withCount() 时指定关联模型的过滤条件。假设,我们有一个评论表(comments),包含一个审核状态(approved)的字段。下面的示例展示了如何对该字段进行过滤,甚至可以指定一个别名:

$users = User::withCount([
    'posts', 
    'comments', 
    'comments as approved_comments_count' => function ($query) {
        $query->where('approved', 1);
    }])
    ->get();

如此,便可在试图中使用 $user->approved_comments_count 来展示统计数据。

若想了解更多关于 withCount() 方法的信息 – 可查看 Laravel 官方文档


Practice makes perfect.

原文地址:https://laraveldaily.com/eloquent-withco...

译文地址:https://learnku.com/laravel/t/29000

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 2

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

社区文档:

将托管在 packagist.org 和 github.com 的扩展包使用国内 CDN 加速
GitHub Laravel 扩展包 TOP 250
速查表方便快速查询框架功能,支持手机访问,支持中英文版本
Laravel 中文文档,由社区用户翻译和维护,将会保持一直更新
此文档的目的,就是为了提高技术团队的凝聚力、一致性和生产效率。
开发环境的部署,开发者工具的选择,适用于 Mac 和 Windows。
浓缩过后的精华
Laravel Nova 后台管理面板文档的中文翻译
Lumen 中文文档,由社区用户翻译和维护,将会保持一直更新
Laravel 下知名扩展包 Dingo API 的中文文档,Laravel API 开发必知必会