Heim > Artikel > Backend-Entwicklung > Laravel5 implementiert die Fuzzy-Matching-Funktion
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!