Suchen einer einzelnen Zeile mit abnehmender Genauigkeit mithilfe mehrerer SELECT-Anweisungen
Bei Datenbankoperationen kann es erforderlich sein, mithilfe von nach einer einzelnen Zeile zu suchen Mehrere Genauigkeitsstufen umfassen die schrittweise Verringerung der Suchkriterien, bis ein Ergebnis gefunden wird. Erwägen Sie beispielsweise die Suche nach einem Bild in einem Tabelle:
Problem:
Zeilen in einer Tabelle finden, die die folgenden Bedingungen erfüllen:
Wenn es für diese Abfrage keine Ergebnisse gibt, versuchen Sie es mit der folgenden Abfrage:
Wenn vorhanden Für diese Abfrage liegen immer noch keine Ergebnisse vor. Versuchen Sie dann die folgende Abfrage:
Lösung:
Mit der UNION ALL-Anweisung können alle diese Abfragen gleichzeitig ausgeführt werden, wodurch eine Suche mit abnehmender Genauigkeit erreicht wird. Diese Anweisung führt verschiedene Abfrageergebnisse in der angegebenen Reihenfolge wie folgt zusammen:
SELECT * FROM image WHERE name = 'text' AND group_id = 10 UNION ALL SELECT * FROM image WHERE name = 'text' UNION ALL SELECT * FROM image WHERE group_id = 10 LIMIT 1;
Optimierung:
Um die Leistung zu verbessern, stellen Sie sicher, dass Sie einen geeigneten Index erstellen wichtig. Für dieses Beispiel wird empfohlen, einen Index für die folgenden Spalten zu erstellen:
durch Hinzufügen der LIMIT 1-Klausel, Postgres Die Leistung kann optimiert werden, indem weitere Abfragen gestoppt werden, nachdem die erste Zeile gefunden wurde, die die Kriterien erfüllt.
Generalisierung:
Diese Methode kann mit beliebig vielen Suchparametern generalisiert werden. Fügen Sie einfach weitere SELECT-Anweisungen innerhalb der UNION ALL-Anweisung hinzu.
Sortieren:
Obwohl die LIMIT 1-Klausel nur eine einzelne Zeile zurückgibt, ist diese Methode möglicherweise nicht praktikabel, wenn Sie die Ergebnisse nach Relevanz sortieren möchten. In diesem Fall ist eine komplexere Abfrage erforderlich, um die Sortierung zu erreichen.
Das obige ist der detaillierte Inhalt vonWie kann ich eine einzelne Zeile mit abnehmender Suchgenauigkeit in SQL effizient finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!