Lösen des „UND“-Schnittpunkts über mehrere Zeilen in SQL
Das Abfragen einer Datenbank zum Abrufen von Daten basierend auf mehreren Bedingungen ist eine häufige Aufgabe. Wenn die Bedingungen jedoch über mehrere Zeilen hinweg angewendet werden müssen, kann der Ansatz komplex werden. In diesem Artikel wird eine effizientere Lösung für solche Szenarien vorgestellt, die Unterabfragen überflüssig macht.
Betrachten Sie die Tabelle „tags“ mit den Spalten „tagid“ und „contentid“. Um die „Content-ID“ jedes mit den Tag-IDs 334, 338 und 342 markierten Inhalts zu finden, werden beim herkömmlichen Ansatz verschachtelte Unterabfragen verwendet. Allerdings wird diese Methode mit zunehmender Anzahl der Bedingungen weniger effizient.
Der optimierte Ansatz vermeidet Unterabfragen, was zu einer schnelleren und erweiterbareren Abfrageleistung führt. Hier ist die überarbeitete Abfrage:
SELECT contentID FROM tags WHERE tagID in (334, 338, 342) GROUP BY contentID HAVING COUNT(DISTINCT tagID) = 3
Diese Abfrage erreicht die Schnittmenge durch Verwendung des „IN“-Operators mit einer Liste von Tagids. Die „GROUP BY“-Klausel gruppiert die Ergebnisse nach „contentID“ und die „HAVING“-Klausel filtert die Ergebnisse so, dass sie nur Inhalte enthalten, die über alle angegebenen Tag-IDs verfügen.
Im Allgemeinen kann dieses Muster zum Suchen erweitert werden die Schnittmenge einer beliebigen Anzahl von Tags:
SELECT contentID FROM tags WHERE tagID in (...) --taglist GROUP BY contentID HAVING COUNT(DISTINCT tagID) = ... --tagcount
Durch Ersetzen der Platzhalter „taglist“ und „tagcount“ durch die gewünschten Werte kann diese Abfrage effizient den Inhalt finden, der die Schnittmenge erfüllt Kriterien.
Das obige ist der detaillierte Inhalt vonWie finde ich effizient den Schnittpunkt mehrerer Zeilenbedingungen in SQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!