Heim > Datenbank > MySQL-Tutorial > Wie wende ich die WHERE-Klauselfilterung in komplexen SQL-Abfragen richtig an?

Wie wende ich die WHERE-Klauselfilterung in komplexen SQL-Abfragen richtig an?

Barbara Streisand
Freigeben: 2025-01-19 10:16:09
Original
986 Leute haben es durchsucht

How to Correctly Apply WHERE Clause Filtering in Complex SQL Queries?

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage