请教一个关于不确定条件个数搜索的问题

当我们在laravel中用条件搜索的时候,不确定本次是多少个条件进行筛选,有可能是一个时间,也有可能是idl和时间,怎么处理这个问题比较简单,总不能不停的判断加条件吧,社区的大神指点下迷津

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 5

tucker-eric/eloquentfilter

3年前 评论

可以把查询条件做成一个数组,例如:

$where = [
    ["name","=",""],
    ["time",">","2021-01-01"]...
];
$result = Model::where($where)->get();

$where里可以放不同的条件,可以是一个,也可以是N个,只不过是并列的条件,or无法实现,因此可以换种思路,还是使用这种方式,通过遍历条件的形式,然后使用查询构造器去构造通用的查询方式。

3年前 评论
$query = User::query();
if ($username = $request->username) {
    $query->where('username', 'LIKE', '%'.$username.'%');
}
if ($email = $request->email) {
    $query->where('email', 'LIKE', '%'.$email.'%');
}
if ($address = $request->address) {
    $query->where('address', 'LIKE', '%'.$address.'%');
}
return $query->get();
3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!