首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel 5模型::with()行为

Laravel 5模型::with()行为
EN

Stack Overflow用户
提问于 2015-02-10 11:38:54
回答 2查看 2.6K关注 0票数 0

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

我的产品模型中的关系:

代码语言:javascript
复制
public function categories(){
    return $this->belongsToMany('App\Category', 'categories_products');
}

在我的主计长中:

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

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

我试着用不同的where子句硬编码,但似乎都被忽略了。我是不是遗漏了什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-10 15:20:09

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

您需要使用whereHas()只返回那些有类别的产品(鼻涕虫?)。

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

或者:

代码语言:javascript
复制
public function getByCategory($slug){
    $return = Product::whereHas('categories', function($query) use ($slug){
        $query->where('slug', 'like', $slug);
    })->paginate(60);
    dd($return);
}

whereHas()添加了一个子查询,用于计数关系的数量。您应该使用DB::getQueryLog()查看雄辩式生成的SQL。弄清楚到底是怎么回事就容易多了!

票数 1
EN

Stack Overflow用户

发布于 2015-02-10 14:55:17

您需要高级子查询吗?如果段塞被定义为产品中的列,则可以这样做:

代码语言:javascript
复制
$return = Product::where('slug', 'like', $slug)->paginate(60);
dd($return);

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

代码语言:javascript
复制
$return = Product::where('slug', 'like', $slug)->categories->paginate(60);
dd($return);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28430737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档