首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel-5如果用户输入不为空,则搜索某些字段

Laravel-5如果用户输入不为空,则搜索某些字段
EN

Stack Overflow用户
提问于 2015-06-11 01:59:30
回答 1查看 498关注 0票数 0

我正在尝试使用Laravel-5构建一个搜索查询,但是我似乎生成了错误的sql。

下面是我使用的代码:

代码语言:javascript
复制
BookingDates::where('status', 'Booked')->where('email', Input::get('email'))->where('name', 'like', '%' . Input::get('name') . '%')->where('date', $date)->get();

然而,有时用户可能不提供电子邮件。当发生这种情况时,应该省略查询的这一部分(where('email', Input::get('email')))。例如,如果他们不提供电子邮件,则会运行以下查询:

代码语言:javascript
复制
BookingDates::where('status', 'Booked')->where('name', 'like', '%' . Input::get('name') . '%')->where('date', $date)->get();

使用Laravel-5有没有简单/漂亮的方法来做这件事?

谢谢。

EN

回答 1

Stack Overflow用户

发布于 2015-06-11 02:16:53

您可以在单独的步骤中构建查询:

代码语言:javascript
复制
$query = BookingDates::where('status', 'Booked')
                     ->where('name', 'like', '%' . Input::get('name') . '%')
                     ->where('date', $date);

if($email = Input::get('email')){
    $query->where('email', $email);
}

$result = $query->get();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30763883

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档