显示Laravel主要类别中的子类别产品

时间:2020-06-13 12:51:46

标签: laravel categories relation levels

我的项目有主要类别-子类别和产品。 每个产品都有一个subcategory_id,每个子类别都有一个category_id。

现在的问题是如何选择和显示与主要类别相关的产品。 通过关系,我得到了$ subcat-> Product之类的子类别产品,或者$ cat-> Subcateogry之类的主要类别的子类别,但是我不知道如何获取主要类别的产品。

进一步清除它:
类别(数字商品)
-子类别(笔记本电脑,手机,电视)
----乘积(l1,l2,m1,m2,t1,t2)

在笔记本电脑子类别视图中,我们有l1和l2,但是如何在主要类别(数字商品)中显示它们。

1 个答案:

答案 0 :(得分:1)

如果您的关系设置正确,则可以使用:

nested eager loading

$allProductInMainCategory=MainCategory::where('id',$mainCategoryId)->
with('subCategories.products')->get();

另一种选择是使用嵌套的whereHas

    $allProductInMainCategory=Product::whereHas('subCategory',function($query)use($mainCategoryId){
            $query->whereHas('mainCategory',function($q)use($mainCategoryId)
            {
                $q->where('mainCategories.id',$mainCategoryId);
            });
})->get();
相关问题