Laravel 5模型::with()行为


Laravel 5 Model::with() behavior

我正试图使用Laravel 5的(L5)Model::with()方法获得一个具有给定类别的产品的简单列表。但L5似乎忽略了where子句的类别。

我的产品模型中的关系:

public function categories(){
    return $this->belongsToMany('App'Category', 'categories_products');
}

在我的控制器中:

public function getByCategory($slug){
    $return = Product::with(array('categories' => function($query) use ($slug){
        $query->where('slug', 'like', $slug);
    }))->paginate(60);
    dd($return);
}

结果是我的数据库中的每个产品的列表,而不仅仅是具有给定类别段塞的产品的列表。

我试着在一些不同的where子句中进行硬编码,但似乎都被忽略了。我是不是错过了什么?

使用with()时,Eloquent不使用联接来查询相关数据,而是使用单独的查询。在您的示例中,它首先获取产品,然后获取相关类别。

您需要使用has()whereHas()仅返回那些具有类别(slugs?)的产品。

public function getByCategory($slug){
    $return = Product::has('categories')->with(array('categories' => function($query) use ($slug){
        $query->where('slug', 'like', $slug);
    }))->paginate(60);
    dd($return);
}

或者:

public function getByCategory($slug){
    $return = Product::whereHas('categories', function($query) use ($slug){
        $query->where('slug', 'like', $slug);
    })->paginate(60);
    dd($return);
}

其中,Has()添加了一个子查询,用于统计关系的数量。您应该使用DB::getQueryLog()来查看Eloquent生成的SQL。让你更容易弄清楚发生了什么!

是否需要高级子查询?如果段塞被定义为产品中的一个柱,你可以这样做:

$return = Product::where('slug', 'like', $slug)->paginate(60);
dd($return);

或者,如果使用关系,您的查询将如下所示:

$return = Product::where('slug', 'like', $slug)->categories->paginate(60);
dd($return);