翼度科技»论坛 编程开发 PHP 查看内容

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

6

主题

6

帖子

18

积分

新手上路

Rank: 1

积分
18
引言

在使用 Laravel 开发应用的时候,还是会经常遇到多条件的查询语句,比如一个网站的商品筛选页面就有可能是这样子:
  1. http://jd.com/products?color=black&size=xl&orderBy=price&sort=desc
复制代码
使用多条件的 where 语句

这种方式的筛选其实我们就会使用多条件的 where 语句来做,比如我们通常会看到类似下面的代码:
  1. $query = Product::newInstance();
  2. if ($request->color) {
  3.     $query->whereColor($request->color);
  4. }
  5. if ($request->size) {
  6.     $query->whereSize($request->size);
  7. }
  8. if ($request->orderBy && $request->sort) {
  9.     $query->orderby($request->orderBy, $request->sort);
  10. }
  11. $products = $query->get();
复制代码
那如果说,你需要一个默认的排序结果的话,可以这样:
  1. ...其他代码
  2. if ($request->orderBy && $request->sort) {
  3.     $query->orderby($request->orderBy, $request->sort);
  4. } else {
  5.     $query->orderby('price', 'desc');
  6. }
  7. ...其他代码
复制代码
使用条件性的 where 查询

然而如果说你使用条件性的 where 查询的话,可以这样:
  1. $products = Product::when($request->color, function ($query) use ($request) {
  2.     return $query->whereColor($request->color);
  3. })
  4. ->when($request->size, function ($query) use ($request) {
  5.    return $query->whereSize($request->size);
  6. })
  7. ->when($request->orderBy && $request->sort, function ($query) use ($request) {
  8.    return $query->orderBy($request->orderBy, $request->sort);
  9. })
  10. ->get();
复制代码
需要默认排序的情况则是这样:
  1. ...其他代码
  2. ->when($request->orderBy && $request->sort, function ($query) use ($request) {
  3.    return $query->orderBy($request->orderBy, $request->sort);
  4. }, function ($query) {
  5.    return $query->latest('price');
  6. })
  7. ...其他代码
复制代码
到这里就可以解决 Laravel 的多条件查询了!
以上就是Laravel多条件where查询语句使用详解的详细内容,更多关于Laravel多条件where查询的资料请关注脚本之家其它相关文章!

来源:https://www.jb51.net/program/290570v2q.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具