阅读(4581)
赞(12)
Laravel 8 条件语句
2021-07-07 09:14:29 更新
有时候你可能想要子句只适用于某个情况为真时才执行查询。例如你可能只想给定值在请求中存在的情况下才应用 where
语句。 你可以通过使用 when
方法来实现:
$role = $request->input('role');
$users = DB::table('users')
->when($role, function ($query, $role) {
return $query->where('role_id', $role);
})
->get();
when
方法只有在第一个参数为 true
的时候才执行给的的闭包。如果第一个参数为 false
,那么这个闭包将不会被执行
你可以传递另一个闭包作为 when
方法的第三个参数。 该闭包会在第一个参数为 false
的情况下执行。为了说明如何使用这个特性,我们来配置一个查询的默认排序:
$sortBy = null;
$users = DB::table('users')
->when($sortBy, function ($query, $sortBy) {
return $query->orderBy($sortBy);
}, function ($query) {
return $query->orderBy('name');
})
->get();