php – Laravel雄辩获得关系计数

我使用Laravel 5.3.

我有2张桌子:

Articles
---------
id
cat_id
title

Category
---------
id
parent_id
title

我在模特中定义了我的关系:

// Article model
public function category()
{
    return $this->belongsTo(Category::class);
}

// Category model
public function children() 
{
    return $this->hasMany(Category::class, 'parent_id', 'id');
}   

有没有一种简单的方法可以使用Eloquent来列出包含文章数量的类别.困难在于我想对id_parent = 0的类别进行分组,即我想只显示包含子项中文章数量的父类别.

我试过这样的事情:

    $category = new \App\Models\Category();
    $categoryTable = $category->getTable();

    return $category->leftJoin('article', 'article.cat_id', '=', 'category.id')
        ->whereIn('article.cat_id', function($query)
            {
                $query->select('cat_id')
                    ->from('categories')
                    ->where('categories.parent_id', ???)
                    ->orWhere($this->tableName .'.cat_id', $id);
            })
        ->groupBy('cat_id');

但我迷路了……

最佳答案
你可以使用withCount().它有5.3版本

有关雄辩访问的更多信息:https://laravel.com/docs/5.3/eloquent-relationships

转载注明原文:php – Laravel雄辩获得关系计数 - 代码日志