Only until Jan 16th: coupon RESOLUTION25 for 40% off Yearly/Lifetime membership!

Read more here

Order by Pivot Fields

When working with belongsToMany and pivot tables, you can create extra columns in the pivot table. Then, use wherePivot() and orderByPivot() to create a separate relationship function in the Model, already filtered/ordered the way you need.

app/Models/User.php:

public function roles(): BelongsToMany
{
return $this->belongsToMany(Role::class)
->withPivot('active')
->withTimestamps();
}
 
public function latestActiveRoles(): BelongsToMany
{
return $this->roles()
->wherePivot('active', 1)
->orderByPivot('created_at', 'desc');
}

Some Controller:

$users = User::with('latestActiveRoles')->get();

Like our articles?

Become a Premium Member for $129/year or $29/month
What else you will get:
  • 69 courses (1205 lessons, total 45 h 02 min)
  • 90 long-form tutorials (one new every week)
  • access to project repositories
  • access to private Discord

Recent New Courses