Prioritätsproblem des WHERE-Parameters in der SQL-Anweisung
Die folgende SQL-Abfrage soll Daten aus der Tabelle „Personen“ abrufen und die Ergebnisse auf Datensätze mit „Universität=2“ beschränken:
<code class="language-sql">SELECT * FROM people WHERE university='2' AND MATCH (lname,fname) AGAINST ('+massive' IN BOOLEAN MODE) OR (fname LIKE '%box%' OR lname LIKE '%box%') </code>
Diese Abfrage führte jedoch zu unerwarteten Ergebnissen, die über die Bedingung „university=2“ hinausgingen. Um dieses Problem zu lösen, müssen wir sicherstellen, dass die Bedingung „Universität = 2“ die Suchergebnisse streng einschränkt.
Passen Sie Klammern an, um die Reihenfolge der Vorgänge zu steuern
Das Problem bei dieser Abfrage ist die unsachgemäße Verwendung von Klammern, die sich auf die Reihenfolge der Auswertung des Ausdrucks auswirkt. In der ursprünglichen Abfrage hat „AND“ eine höhere Priorität als „OR“, was bedeutet, dass es zuerst ausgewertet wird. Daher wird „university=2“ nur mit „MATCH (lname,fname) AGAINST ('massive' IN BOOLEAN MODE)“ und nicht mit dem „fname/lname“-Test kombiniert.
Um dies zu korrigieren, müssen wir die Klammern anpassen, um sicherzustellen, dass „university=2“ mit dem gesamten Suchkriterium kombiniert wird:
<code class="language-sql">SELECT * FROM people WHERE university='2' AND (MATCH (lname,fname) AGAINST ('+massive' IN BOOLEAN MODE) OR fname LIKE '%box%' OR lname LIKE '%box%') </code>
Mit dieser Anpassung wird die Bedingung „university=2“ nun in Klammern eingeschlossen, was darauf hinweist, dass sie zuerst ausgewertet und dann mit den Suchbedingungen innerhalb des zweiten Satzes von Klammern kombiniert werden sollte. Dadurch wird sichergestellt, dass bei der Suche nur Datensätze berücksichtigt werden, bei denen „university=2“ wahr ist.
Das obige ist der detaillierte Inhalt vonWie wende ich die WHERE-Klauselfilterung in komplexen SQL-Abfragen richtig an?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!