上下文
我使用 Laravel 的 Eloquent作为我的 ORM。我正在创建一个 API 端点,它提供对Cars
具有多个属性 ( color
, make
, status
) 的访问。
我的端点允许客户端通过这些属性的任何子集过滤返回值,如果它们不提供任何属性,那么我将返回所有内容。
问题
我想构建一个条件查询,它从“全部”开始,并根据指定的参数缩小范围。这是我写的:
public function getCars(Request $request)
{
$results = Cars::all();
if($request->has('color'))
$results = $results->where('color', $request->input('color'));
if($request->has('make'))
$results = $results->where('make', $request->input('make'));
if($request->has('status'))
$results = $results->where('status', $request->input('status'));
return $results->toJson();
}
如果我不带参数调用它,API 会返回数据库中所有汽车的列表。但是,如果我指定(例如)0
API 的状态返回一个空集,尽管有些汽车的状态为0
.
我是在错误地接近这个吗?我缺少一些基本的东西吗?
请注意,如果我写的是:
$results = Cars::where('status', 0);
return $results->get();
正确生成汽车列表