Laravel 5.3 withCount() nested relation

32,110

You can only do a withCount() on a defined relation of the model.

However, a relationship can be hasManyThrough which would achieve what you are after.

class Tutorial extends Model
{
    function chapters()
    {
        return $this->hasMany('App\Chapter');
    }

    function videos()
    {
        return $this->hasManyThrough('App\Video', 'App\Chapter');
    }
}

And then you can do:

Tutorial::withCount(['chapters', 'videos'])

Docs:

Share:
32,110
Sahil Deliwala
Author by

Sahil Deliwala

Updated on November 08, 2020

Comments

  • Sahil Deliwala
    Sahil Deliwala over 3 years

    The model structure is as follows

    Tutorial -> (hasMany) Chapters -> (hasMany) videos

    How can we load number of videos (video_count) from Tutorial Model with laravel 5.3's withCount() method

    I have tried:

    Tutorial::withCount('chapters')
    ->withCount('chapters.videos') // this gives error: Call to undefined method Illuminate\Database\Query\Builder::chapters.videos()
    ->all();
    

    Edit

    This works, Any Better solution?

    Tutorial::withCount('chapters')
    ->with(['chapters' => function($query){
        $query->withCount('videos');
    }])
    ->all();