Heim  >  Artikel  >  Backend-Entwicklung  >  Laravel5 implementiert die Fuzzy-Matching-Funktion

Laravel5 implementiert die Fuzzy-Matching-Funktion

小云云
小云云Original
2018-03-26 09:16:512304Durchsuche

In diesem Artikel wird hauptsächlich die Methode zur Implementierung von Fuzzy-Matching und Multi-Bedingungs-Abfragefunktionen in Laravel5 vorgestellt und die Fähigkeiten von Laravel5-Fuzzy-Abfragen und zugehörigen Verpackungsvorgängen anhand von Beispielen analysiert.

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;
}

Die oben genannten $data werden von vorne übergeben End-Arrays verwenden Kapselung und Spleißen für eine Fuzzy- oder präzise Suche mit mehreren Bedingungen.

Der Nachteil besteht darin, dass der Code nicht robust und nicht wartungsfreundlich ist

Methode 2. Es wird die Kapselungsmethode des Masters verwendet. Wissen ist ein 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;
}

Verwandte Empfehlungen:

Regulärer Ausdruck, um Zeichenunschärfe zu erreichen. Beispiel für eine Matching-Funktion

JS-Nachahmung der automatischen Fuzzy-Matching-Eingabeaufforderung von Baidu im Dropdown-Feld

Fuzzy-Matching-IP für reguläre Javascript-Ausdrücke Beispiel einer Adressfunktion

Das obige ist der detaillierte Inhalt vonLaravel5 implementiert die Fuzzy-Matching-Funktion. 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