ลาราเวล. ใช้ขอบเขต () ในโมเดลที่มีความสัมพันธ์


105

ฉันมีโมเดลที่เกี่ยวข้องสองแบบ: CategoryและPost.

Postรูปแบบมีpublishedขอบเขต (วิธีการscopePublished())

เมื่อฉันพยายามรับทุกหมวดหมู่ด้วยขอบเขตนั้น:

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

ฉันได้รับข้อผิดพลาด:

โทรหาวิธีที่ไม่ได้กำหนด published()

ประเภท:

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

โพสต์:

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


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

}

คำตอบ:


185

คุณสามารถทำได้แบบอินไลน์:

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

คุณยังสามารถกำหนดความสัมพันธ์:

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

แล้ว:

//all posts
$category->posts;

// published only
$category->postsPublished;

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

6
อนึ่งหากคุณต้องการรับเฉพาะตำแหน่งที่คุณเผยแพร่โพสต์:Category::whereHas('posts', function ($q) { $q->published(); })->get();
tptcat

2
@tptcat ใช่ ยังสามารถเป็นCategory::has('postsPublished')ในกรณีนี้
Jarek Tkaczyk

คำถามสะอาดคำตอบสะอาด!
Mojtaba Hn
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.