Heim >Backend-Entwicklung >PHP-Tutorial >Methode zur Implementierung von Fuzzy-Matching und Abfragefunktionen mit mehreren Bedingungen in Laravel5

Methode zur Implementierung von Fuzzy-Matching und Abfragefunktionen mit mehreren Bedingungen in Laravel5

不言
不言Original
2018-06-06 11:01:502167Durchsuche

In diesem Artikel wird hauptsächlich die Methode zur Implementierung von Fuzzy-Matching und Multi-Condition-Abfragefunktionen in Laravel5 vorgestellt. Er analysiert die Multi-Condition-Fuzzy-Abfrage und die damit verbundenen Verpackungsoperationsfähigkeiten in Form von Beispielen

Das Beispiel dieses Artikels beschreibt die Methode zur Implementierung von Fuzzy-Matching und Abfragefunktionen mit mehreren Bedingungen in Laravel5. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Methode 1. ORM-Modus


public function ReportAccurate($data)
{
 if(is_array($data))
 {
   $where = $this->whereAll($data);
   return $where;
 }
 else
 {
   return false;
 }
}
/*多条件模糊*/
public function whereAll($data)
{
  $query = new ReportMainpage();
  $results = $query->where(function ($query) use ($data) {
    $data['report_first_received_date'] && $query->where('report_first_received_date', 'like', '%' . $data['report_first_received_date'] . '%');
    $data['report_drug_safety_date'] && $query->where('report_drug_safety_date', 'like', '%' . $data['report_drug_safety_date'] . '%');
    $data['aecountry_id'] && $query->where('aecountry_id', $data['aecountry_id']);
    $data['received_fromid_id'] && $query->where('received_fromid_id', $data['received_fromid_id']);
    $data['research_id'] && $query->where('research_id', 'like', '%' . $data['research_id'] . '%');
    $data['center_number'] && $query->where('center_number', 'like', '%' . $data['center_number'] . '%');
  })->get();
  return $results;
}


Bei den $data oben handelt es sich um das vom Frontend übergebene Array, das Kapselung und Spleißen für die Fuzzy- oder präzise Suche mit mehreren Bedingungen verwendet.

Das Schlimme ist, dass der Code ist nicht robust und nicht wartungsfreundlich

Methode 2. Das von der Master-Verpackungsmethode verwendete Wissen ist das Repository-Lager


$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'];
/*查询的字段*/
$searchFields = [
  'report_identify' => 'like',
  'drug_name' => 'like',
  'event_term' => 'like',
  'organize_role_id' => '=',
  'case_causality' => '=',
  'report_type' => '=',
  'task_user_id' => '=',
  'status' => '=',
];
/*获取查询条件*/
$where = $this->searchArray($searchFields);
/*获取数据*/
$this->reportTaskRepo->pushCriteria(new OrderBySortCriteria('asc', 'task_countdown'));
$data = $this->reportTaskRepo->findWhere($where, $fields);
//在Trait里封装
/**
 * 获取请求中的参数的值
 * @param array $fields [description]
 * @return [type]     [description]
 */
public function searchArray($fields=[])
{
  $results = [];
  if (is_array($fields)) {
   foreach($fields as $field => $operator) {
     if(request()->has($field) && $value = $this->checkParam($field, '', false)) {
      $results[$field] = [$field, $operator, "%{$value}%"];
     }
   }
  }
  return $results;
}


Das obige ist der detaillierte Inhalt vonMethode zur Implementierung von Fuzzy-Matching und Abfragefunktionen mit mehreren Bedingungen in Laravel5. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn