Laravel 5 Model::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);
}
结果是我数据库中每个产品的列表,而不仅仅是具有给定类别 slug 的产品列表。
我尝试在一些不同的 where 子句中进行硬编码,但似乎都被忽略了。我错过了什么吗?
您需要高级子查询吗?如果 slug 被定义为产品中的一列,你可以这样做:
$return = Product::where('slug', 'like', $slug)->paginate(60);
dd($return);
或者,如果使用关系,您的查询将如下所示:
$return = Product::where('slug', 'like', $slug)->categories->paginate(60);
dd($return);
Eloquent在使用with()时不使用join来查询相关数据,而是使用separate查询。在您的示例中,它首先获取产品,然后获取相关类别。
您需要使用 has()
or whereHas()
到 return 只有那些有类别的产品(鼻涕虫?)。
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);
}
whereHas() 添加了一个计算关系数的子查询。您应该使用 DB::getQueryLog() 来查看 Eloquent 生成的 SQL。更容易弄清楚发生了什么!
我正在尝试使用 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);
}
结果是我数据库中每个产品的列表,而不仅仅是具有给定类别 slug 的产品列表。
我尝试在一些不同的 where 子句中进行硬编码,但似乎都被忽略了。我错过了什么吗?
您需要高级子查询吗?如果 slug 被定义为产品中的一列,你可以这样做:
$return = Product::where('slug', 'like', $slug)->paginate(60);
dd($return);
或者,如果使用关系,您的查询将如下所示:
$return = Product::where('slug', 'like', $slug)->categories->paginate(60);
dd($return);
Eloquent在使用with()时不使用join来查询相关数据,而是使用separate查询。在您的示例中,它首先获取产品,然后获取相关类别。
您需要使用 has()
or whereHas()
到 return 只有那些有类别的产品(鼻涕虫?)。
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);
}
whereHas() 添加了一个计算关系数的子查询。您应该使用 DB::getQueryLog() 来查看 Eloquent 生成的 SQL。更容易弄清楚发生了什么!