当前位置:首页 > CMS教程 > 其它CMS > 列表

Laravel5中实现模糊匹配加多条件查询功能的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-09-05 17:03:13 浏览: 评论:0 

这篇文章主要介绍了Laravel5中实现模糊匹配加多条件查询功能的方法,结合实例形式分析了Laravel5多条件模糊查询及相关封装操作技巧,需要的朋友可以参考下。

本文实例讲述了Laravel5中实现模糊匹配加多条件查询功能的方法,分享给大家供大家参考,具体如下:

方法1. ORM模式

  1. public function ReportAccurate($data
  2.  if(is_array($data)) 
  3.  { 
  4.    $where = $this->whereAll($data); 
  5.    return $where
  6.  } 
  7.  else 
  8.  { 
  9.    return false; 
  10.  } 
  11. /*多条件模糊*/ 
  12. public function whereAll($data
  13.   $query = new ReportMainpage(); 
  14.   $results = $query->where(function ($queryuse ($data) { 
  15.     $data['report_first_received_date'] && $query->where('report_first_received_date''like''%' . $data['report_first_received_date'] . '%'); 
  16.     $data['report_drug_safety_date'] && $query->where('report_drug_safety_date''like''%' . $data['report_drug_safety_date'] . '%'); 
  17.     $data['aecountry_id'] && $query->where('aecountry_id'$data['aecountry_id']); 
  18.     $data['received_fromid_id'] && $query->where('received_fromid_id'$data['received_fromid_id']); 
  19.     $data['research_id'] && $query->where('research_id''like''%' . $data['research_id'] . '%'); 
  20.     $data['center_number'] && $query->where('center_number''like''%' . $data['center_number'] . '%'); 
  21.   })->get(); 
  22.   return $results

上面的$data为前端传过来的数组 利用封装拼接进行模糊或者精确的多条件搜素

不好的地方 代码不健壮 不利于维护

方法2. 大神封装法 利用到的知识是Repository 仓库

  1. $fields = ['id''report_id''report_identify''report_first_received_date''drug_name''first_event_term''case_serious''standard_of_seriousness''case_causality''received_from_id''task_user_name''organize_role_name''task_countdown''report_countdown']; 
  2. /*查询的字段*/ 
  3. $searchFields = [ 
  4.   'report_identify' => 'like'
  5.   'drug_name' => 'like'
  6.   'event_term' => 'like'
  7.   'organize_role_id' => '='
  8.   'case_causality' => '='
  9.   'report_type' => '='
  10.   'task_user_id' => '='
  11.   'status' => '='
  12. ]; 
  13. /*获取查询条件*/ 
  14. $where = $this->searchArray($searchFields); 
  15. /*获取数据*/ 
  16. $this->reportTaskRepo->pushCriteria(new OrderBySortCriteria('asc''task_countdown')); 
  17. $data = $this->reportTaskRepo->findWhere($where$fields); 
  18. //在Trait里封装 
  19. /** 
  20.  * 获取请求中的参数的值 
  21.  * @param array $fields [description] 
  22.  * @return [type]     [description] 
  23.  */ 
  24. public function searchArray($fields=[]) 
  25.   $results = []; 
  26.   if (is_array($fields)) { 
  27.    foreach($fields as $field => $operator) { 
  28.      if(request()->has($field) && $value = $this->checkParam($field'', false)) { 
  29.       $results[$field] = [$field$operator"%{$value}%"]; 
  30.      } 
  31.    } 
  32.   } 
  33.   return $results
  34. }

Tags: Laravel模糊匹配 Laravel条件查询

分享到: