Laravel多条件where查询语句使用详解

 更新时间:2023年06月28日 11:33:37   作者:JellyBool  
这篇文章主要为大家介绍了Laravel多条件where查询语句使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

引言

在使用 Laravel 开发应用的时候,还是会经常遇到多条件的查询语句,比如一个网站的商品筛选页面就有可能是这样子:

http://jd.com/products?color=black&size=xl&orderBy=price&sort=desc

使用多条件的 where 语句

这种方式的筛选其实我们就会使用多条件的 where 语句来做,比如我们通常会看到类似下面的代码:

$query = Product::newInstance();
if ($request->color) {
    $query->whereColor($request->color);
}
if ($request->size) {
    $query->whereSize($request->size);
}
if ($request->orderBy && $request->sort) {
    $query->orderby($request->orderBy, $request->sort);
}
$products = $query->get();

那如果说,你需要一个默认的排序结果的话,可以这样:

...其他代码
if ($request->orderBy && $request->sort) {
    $query->orderby($request->orderBy, $request->sort);
} else {
    $query->orderby('price', 'desc');
}
...其他代码

使用条件性的 where 查询

然而如果说你使用条件性的 where 查询的话,可以这样:

$products = Product::when($request->color, function ($query) use ($request) {
    return $query->whereColor($request->color);
})
->when($request->size, function ($query) use ($request) {
   return $query->whereSize($request->size);
})
->when($request->orderBy && $request->sort, function ($query) use ($request) {
   return $query->orderBy($request->orderBy, $request->sort);
})
->get();

需要默认排序的情况则是这样:

...其他代码
->when($request->orderBy && $request->sort, function ($query) use ($request) {
   return $query->orderBy($request->orderBy, $request->sort);
}, function ($query) {
   return $query->latest('price');
})
...其他代码

到这里就可以解决 Laravel 的多条件查询了!

以上就是Laravel多条件where查询语句使用详解的详细内容,更多关于Laravel多条件where查询的资料请关注脚本之家其它相关文章!

相关文章

  • php实现paypal 授权登录

    php实现paypal 授权登录

    本文给大家分享的是php实现的paypal授权登录的代码,十分的简单实用,有需要的小伙伴可以参考下。
    2015-05-05
  • php时间戳转换的示例

    php时间戳转换的示例

    PHP获取“今天的时间戳”,再通过“今天”获取昨天和明天0点和23:59:59的时间戳
    2014-03-03
  • 基于php+MySql实现学生信息管理系统实例

    基于php+MySql实现学生信息管理系统实例

    这篇文章主要介绍了基于php+MySql实现学生信息管理系统实例,文中通过图片功能介绍的非常详细,文章末尾附带项目源码,需要的朋友可以参考下
    2020-08-08
  • 阿里云Win2016安装Apache和PHP环境图文教程

    阿里云Win2016安装Apache和PHP环境图文教程

    本文给大家讲述的是在阿里云的WindowsServer2016上部署Apache和PHP的web环境,步骤非常细致,强烈推荐给大家
    2018-03-03
  • tp5 实现列表数据根据状态排序

    tp5 实现列表数据根据状态排序

    今天小编就为大家分享一篇tp5 实现列表数据根据状态排序,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • 基于Laravel 多个中间件的执行顺序详解

    基于Laravel 多个中间件的执行顺序详解

    今天小编就为大家分享一篇基于Laravel 多个中间件的执行顺序详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • 基于PHP实现用户在线状态检测

    基于PHP实现用户在线状态检测

    这篇文章主要介绍了基于PHP实现用户在线状态检测,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • PHP加密技术的简单实现

    PHP加密技术的简单实现

    下面小编就为大家带来一篇PHP加密技术的简单实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • Yii 框架应用(Applications)操作实例详解

    Yii 框架应用(Applications)操作实例详解

    这篇文章主要介绍了Yii 框架应用(Applications)操作,结合实例形式详细分析了Yii 框架应用(Applications)基本配置、属性、事件相关操作技巧与注意事项,需要的朋友可以参考下
    2020-05-05
  • smarty模板引擎使用内建函数foreach循环取出所有数组值的方法

    smarty模板引擎使用内建函数foreach循环取出所有数组值的方法

    这篇文章主要介绍了smarty模板引擎使用内建函数foreach循环取出所有数组值的方法,实例分析了foreach循环遍历数组的几种常用技巧,需要的朋友可以参考下
    2015-01-01

最新评论