Heim >Backend-Entwicklung >PHP-Tutorial >Wie optimiere ich den Levenshtein-String-Vergleich in MySQL mit PHP?

Wie optimiere ich den Levenshtein-String-Vergleich in MySQL mit PHP?

Linda Hamilton
Linda HamiltonOriginal
2024-12-02 22:02:11557Durchsuche

How to Optimize Levenshtein String Comparison in MySQL with PHP?

MySQL Levenshtein mit PHP: Optimierung

Diese Frage untersucht einen effizienten MySQL-Ansatz zur Durchführung eines Levenshtein-Stringvergleichs innerhalb eines PHP-Skripts. Das bereitgestellte Code-Snippet in PHP ruft Begriffe aus einer Datenbanktabelle ab und wendet die Funktion levenshtein() an, um den Bearbeitungsabstand zwischen jedem abgerufenen Begriff und einem vom Benutzer bereitgestellten Begriff zu berechnen. Allerdings führt der Code mehrere Abfragen aus und filtert Ergebnisse in PHP, was ineffizient sein kann.

Um dieses Problem zu beheben, besteht eine optimalere Lösung darin, eine MySQL-Funktion für Levenshtein-Entfernungsberechnungen zu verwenden. So würde der überarbeitete Code aussehen:

$word = mysql_real_escape_string($word);
mysql_query("SELECT `term` FROM `words` WHERE levenshtein('$word', `term`) BETWEEN 0 AND 4");

Dieser Code fragt die Worttabelle ab und filtert die Ergebnisse mithilfe der Funktion levenshtein() innerhalb einer einzigen Abfrage. Die Funktion berechnet den Bearbeitungsabstand zwischen dem vom Benutzer eingegebenen Begriff und jedem Begriff in der Tabelle. Die BETWEEN-Bedingung beschränkt die Ergebnisse auf Begriffe mit einem Bearbeitungsabstand zwischen 0 und 4. Dadurch entfällt die Notwendigkeit mehrerer Abfragen und PHP-basierter Filterung, was zu einer effizienteren Lösung führt.

Das obige ist der detaillierte Inhalt vonWie optimiere ich den Levenshtein-String-Vergleich in MySQL mit PHP?. 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