Laravel雄辩的非lambda参数 - php

我正在尝试使用雄辩的方法从数据库中检索许多结果。
我对此没有问题。
范例程式码

$flights = App\Flight::where('active', 1)
               ->orderBy('name', 'desc')
               ->take(10)
               ->get();

现在,假设我有一个变量,如果为true,我想再添加一个WHERE子句。例如,如果$ domestic == true,那么我想要这样的事情:

$flights = App\Flight::where('active', 1)
               ->where('domestic',1)
               ->orderBy('name', 'desc')
               ->take(10)
               ->get();

所以我不喜欢这样做,因为它不好。

if($domestic) { 
$flights = App\Flight::where('active', 1)
                   ->where('domestic',1)
                   ->orderBy('name', 'desc')
                   ->take(10)
                   ->get();
} else {
$flights = App\Flight::where('active', 1)
                   ->orderBy('name', 'desc')
                   ->take(10)
                   ->get();
}

理想情况下,我只想传递where子句。

if(@domestic) { $flights->where('domestic',1) } 

但这是行不通的。

在需要时传递附加的where子句的最佳方法是什么?

参考方案

$flights = App\Flight::where('active', 1)
    ->orderBy('name', 'desc')
    ->when($domestic, function ($query){
        return $query->where('domestic',1)
    })
    ->take(10)
    ->get();

laravel查询生成器有一些真正的宝石,例如when子句,when子句仅在第一个参数为true时才执行闭包(在这种情况下为$domestic

可以在here中找到此特定功能。同样,可以找到更多这些功能。

PHP:对数组排序 - php

请如何排序以下数组Array ( 'ben' => 1.0, 'ken' => 2.0, 'sam' => 1.5 ) 至Array ( 'ken' => 2.0, 'sam' => 1.5, 'ben' =&…

PHP strtotime困境 - php

有人可以解释为什么这在我的服务器上输出为true吗?date_default_timezone_set('Europe/Bucharest'); var_dump( strtotime('29.03.2015 03:00', time()) === strtotime('29.03.2015 04:00�…

PHP-全局变量的性能和内存问题 - php

假设情况:我在php中运行一个复杂的站点,并且我使用了很多全局变量。我可以将变量存储在现有的全局范围内,例如$_REQUEST['userInfo'],$_REQUEST['foo']和$_REQUEST['bar']等,然后将许多不同的内容放入请求范围内(这将是适当的用法,因为这些数据指的是要求自…

php-casperjs获取内部文本 - php

我正在为casperjs使用php包装器-https://github.com/alwex/php-casperjs我正在网上自动化一些重复的工作,我需要访问一个项目的innerText,但是我尚不清楚如何从casperjs浏览器访问dom。我认为在js中我会var arr = document.querySelector('label.input…

PHP PDO组按列名称查询结果 - php

以下PDO查询返回以下结果:$db = new PDO('....'); $sth = $db->prepare('SELECT ...'); 结果如下: name curso ABC stack CDE stack FGH stack IJK stack LMN overflow OPQ overflow RS…