


Wie kann ich Felder in der MySQL-Volltextsuche priorisieren, um ihre Relevanz zu erhöhen?
Nov 03, 2024 pm 11:37 PMPriorisierung von Feldern in der MySQL-Volltextsuche für erhöhte Relevanz
Angenommen, Sie stoßen auf eine Situation, in der Sie zwei Spalten haben, „Schlüsselwörter“ und „Inhalt“. ,“ in einer Tabelle und einem zugrunde liegenden Volltextindex, der beide Spalten umfasst. Sie möchten jedoch Zeilen, die einen bestimmten Begriff in der Spalte „Schlüsselwörter“ enthalten, eine höhere Relevanz verleihen als denen, die ihn in der Spalte „Inhalt“ enthalten.
Um diese Aufgabe im Zusammenhang mit der Verwendung der Funktion „Abgleichen gegen“ zu erfüllen Syntax können Sie einen vielschichtigen Ansatz implementieren:
-
Mehrere Volltextindizes erstellen:
Drei Volltextindizes erstellen:- Eine allein in der Spalte „Schlüsselwörter“
- Eine allein in der Spalte „Inhalt“
- Eine sowohl in der Spalte „Schlüsselwörter“ als auch in der Spalte „Inhalt“
-
Nutzen Sie die gewichtete Relevanzberechnung:
Rufen Sie in Ihrer Abfrage die Relevanzwerte für die Übereinstimmungen „Keywords“ und „Inhalt“ separat ab. Kombinieren Sie diese Ergebnisse dann mithilfe einer gewichteten Addition und weisen Sie der Relevanz der „Schlüsselwörter“ ein höheres Gewicht zu:SELECT id, keyword, content, MATCH (keyword) AGAINST ('watermelon') AS rel1, MATCH (content) AGAINST ('watermelon') AS rel2 FROM table WHERE MATCH (keyword,content) AGAINST ('watermelon') ORDER BY (rel1*weight_factor)+(rel2) DESC
Nach dem Login kopieren -
Kontrollrückruf mit dem kombinierten Index:
Während die Da die obige Berechnung die Relevanz bestimmt, ist es wichtig, die Indexnutzung für Suche und Relevanz zu trennen. Nutzen Sie den Index sowohl für „Schlüsselwörter“ als auch für „Inhalt“, um die Erinnerung zu steuern und sicherzustellen, dass relevante Zeilen in den Suchergebnissen zurückgegeben werden.
Mit diesem Ansatz können Sie die Wichtigkeit der Spalte „Schlüsselwörter“ priorisieren zur Bestimmung der Dokumentrelevanz in Ihren MySQL-Volltextsuchanfragen. Der Gewichtungsfaktor in der Berechnung ermöglicht Ihnen eine Feinabstimmung der Priorität übereinstimmender Begriffe in der gewünschten Spalte.
Das obige ist der detaillierte Inhalt vonWie kann ich Felder in der MySQL-Volltextsuche priorisieren, um ihre Relevanz zu erhöhen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung?

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin)

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung

Wie konfiguriere ich die SSL/TLS -Verschlüsselung für MySQL -Verbindungen?

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)?
