Laravel. Verwenden Sie scope () in Modellen mit Beziehung


101

Ich habe zwei verwandte Modelle: CategoryundPost .

Das PostModell hat einen publishedGeltungsbereich (Methode scopePublished()).

Wenn ich versuche, alle Kategorien mit diesem Bereich zu erhalten:

$categories = Category::with('posts')->published()->get();

Ich erhalte eine Fehlermeldung:

Aufruf einer undefinierten Methode published()

Kategorie:

class Category extends \Eloquent
{
    public function posts()
    {
        return $this->HasMany('Post');
    }
}

Post:

class Post extends \Eloquent
{
   public function category()
   {
       return $this->belongsTo('Category');
   }


   public function scopePublished($query)
   {
       return $query->where('published', 1);
   }

}

Antworten:


178

Sie können es inline tun:

$categories = Category::with(['posts' => function ($q) {
  $q->published();
}])->get();

Sie können auch eine Beziehung definieren:

public function postsPublished()
{
   return $this->hasMany('Post')->published();
   // or this way:
   // return $this->posts()->published();
}

und dann:

//all posts
$category->posts;

// published only
$category->postsPublished;

// eager loading
$categories->with('postsPublished')->get();

6
Übrigens, wenn Sie NUR dort Category::whereHas('posts', function ($q) { $q->published(); })->get();
ankommen

2
@tptcat ja. Kann auch Category::has('postsPublished')in diesem Fall sein
Jarek Tkaczyk

Saubere Frage, saubere Antwort!
Mojtaba Hn
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.