小编sle*_*ess的帖子

Laravel - 有没有办法结合哪里有和有

我目前面临一个小问题.我想仅在存在具有特定条件的关系时才返回模型.使用whereHas()方法可以正常工作.

$m = Model
    ::whereHas(
        'programs',
        function($q) {
            $q->active();
        }
    );
Run Code Online (Sandbox Code Playgroud)

但是,将关系称为此类属性将为我提供所有(未过滤结果).

$m->programs;
Run Code Online (Sandbox Code Playgroud)

基本上我现在正在做的是:

$m = Model
    ::whereHas(
        'programs',
        function($q) {
            $q->active();
        }
    )
    ->with(array('programs' => function($q) {
        $q->active();
    }))
;
Run Code Online (Sandbox Code Playgroud)

这工作正常但我觉得再次做同样的事情非常糟糕.这不是正确的方法.如何在不重复代码的情况下实现这一目标?

php laravel laravel-4

3
推荐指数
1
解决办法
1119
查看次数

标签 统计

laravel ×1

laravel-4 ×1

php ×1