sql语句,有条件按条件查询,没条件则查询全部

场景:很多时候我们遇到查询问题的解决,都是条件比较少的查询。一般都是if判断那个条件是否存在,存在则用where查询条件,不存在则直接查询全部。这样只能解决一两个条件查询。如果条件比较多的话,我们需要做的if判断的次数就是n的次方

第一个例子

假设我们有一个用户表users,我们条件查询的有三个字段,age,name,class

解决思路。我们先从我们需要的结果查起。我们需要的结果可能是以下结果
1.   select * from users;
2.  select * from users where age = $age;
3.  select * from users where name = $name;
4.  select * from users where class = $class;
5.  select * from users where age = $age and name = $name and class = $class
..... 一共会有十种(3*3+1)可能性;
我们观察下,可以看到 select * from users 这句话是一直存在的,但是后面的where条件是变动的。
于是,我们可以把where条件作为一个变量  即 select * from users $where
我们在实际项目中,代码可以是这样
//  首先可以获取条件变量,我们直接把他们存到一个数组里面,并且键,一定要与我们的字段名相对应
$arr = array();
$newarr = array();
//  注意,此处的$arr定义不定义都可以,以为即使变量没值,也会赋值没个键为空
//  但是$newarr必须先预定义为数组。因为如果下面foreach遍历$arr的话,$arr如果为空,$newarr是没有键和值的,就会报错没有预定义
 $arr['age']= $_POST['age']?$_POST['age']:'';
 $arr['name'] = $_POST['name']?$_POST['name']:'';
 $arr['class'] = $_POST['class']?$_POST['class']:'';
//  这个时候我们得到的数组,即使值是空,也会存在于$arr字段里面。那么,我们需要去掉无用的搜索字段,
// 即,$arr['xx''] == null的字段,或者也可以说是empty($arr['xx'])的字段

foreach ($arr as $key => $val){
//  遍历数组,如果值不为空,则组合到新的数组$newarr[]里面。注意要把键带上
            if(!empty($val)){
                $newarr[$key] = $val;
            }
        }

我们打印下$newarr可以看到结果如下图。正是用户查询的字段条件

《sql语句,有条件按条件查询,没条件则查询全部》 $arr可以不预定义
《sql语句,有条件按条件查询,没条件则查询全部》 dd($newarr)

  • 我们知道,数组可以直接放进where条件查询的。我们先打印一个where是数组的条件语句试下

《sql语句,有条件按条件查询,没条件则查询全部》 image.png

那么 此时我们的查询语句可以写成这样

        if ($newarr==null){
      //      或者 if(empty($newarr))
            $res = \DB::table('users')->get();
        }else{
            $res = \DB::table('users')->where($newarr)->get();
        }
注意---我们这里用到了$newarr变量,我们一定要在使用之前先定义$newarr=array(),不然会报错未定义Undefined
  • 下面把做好的代码展示下
public function test3()
    {
        $newarr = array();
        $arr['age']= $_POST['age']?$_POST['age']:'';
        $arr['name'] = $_POST['name']?$_POST['name']:'';
        $arr['class'] = $_POST['class']?$_POST['class']:'';

        foreach ($arr as $key => $val){
            if(!empty($val)){
                $newarr[$key] = $val;
            }
        }
        if ($newarr==null){
//            或者 if(empty($newarr))
            $res = \DB::table('users')->get();
        }else{
            $res = \DB::table('users')->where($newarr)->get();
        }

        dd($res);

    }
其实如果我们想简单一点,可以直接$where = $request->except(['不需要的字段']);
  这个前提是,我们请求的字段必须与我们数据表的字段相对应
我们只需要检查$where 也就是我们接受到的查询条件是否为空就行了

第二个例子

如果我们的条件查询是两个类别的字段,则只需判断是那个类别的字段即可,比如下面的图1,兼职分类地区分类是由两个分类表(图2)遍历到模版的。

《sql语句,有条件按条件查询,没条件则查询全部》 图1.png
《sql语句,有条件按条件查询,没条件则查询全部》 图2

控制器   Route::get('/', 'HomeController@index');
在blade模版里面
<div class="row">
        @foreach($tagjobs as $data)
            <div class="col-md-2 text-center"><a href="{{ url('/?tag_job_id='.$data->id) }}">{{ $data->name }}</a></div>
        @endforeach
    </div>
    <div class="row">
        @foreach($tagsarea as $data)
            <div class="col-md-2 text-center"><a href="{{ url('/?tag_area_id='.$data->id) }}">{{ $data->name }}</a></div>
        @endforeach
    </div>

控制器里面 。 如果由条件则按条件查询,没条件则查询出来全部
    public function index(Request $request)
    {
//        $tag_area_id = $request->input('tag_area_id');
//        $tag_job_id = $request->input('tag_job_id');
////        先检查tag_area_id是否存在,存在则查询,不存在则查看tag_job_id是否存在。也不存在则是全部
//        if ($tag_area_id ){
//           $where = ['tag_area_id'=>$tag_area_id];
//        }else{
//            if ($tag_job_id  ){
//                $where = ['tag_job_id'=>$tag_job_id];
//            }else{
//                $where = null;
//            }
//        }
// 因为我们后面的参数直接就是对应的job_publish字段,所以我们可以直接 $request->all();获取条件    
    $where = $request->all();
        if ($where==null){
            $jobpublishs = DB::table('job_publish')->get();
        }else{
            $jobpublishs = DB::table('job_publish')->where($where)->get();
        }
        return view('home',compact('jobpublishs'));

    }

《sql语句,有条件按条件查询,没条件则查询全部》 dd(\Request::all()); 的结果

    原文作者:小龙123
    原文地址: https://www.jianshu.com/p/b1b7e5069a1f
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞