Heim > Datenbank > MySQL-Tutorial > Warum führt das Mischen von ANSI 1992-Joins und Kommas in MySQL-Abfragen zu Fehlern?

Warum führt das Mischen von ANSI 1992-Joins und Kommas in MySQL-Abfragen zu Fehlern?

Barbara Streisand
Freigeben: 2025-01-09 10:51:42
Original
607 Leute haben es durchsucht

Why Does Mixing ANSI 1992 Joins and Commas in MySQL Queries Cause Errors?

Der Grund, warum die gemischte Verwendung der ANSI 1992 JOIN-Syntax und Kommas in MySQL-Abfragen Fehler verursacht

Wenn Sie mehrere Tabellen in einer MySQL-Abfrage verknüpfen, achten Sie darauf, konsequent die ANSI 1992 JOIN-Syntax oder die durch Kommas getrennte Notation zu verwenden. Das Mischen dieser beiden Methoden kann zu Fehlern wie dem Fehler „Unbekannte Spalte „m.id“ in „on-Klausel““ führen.

Fehlergrund

In der folgenden Abfrage:

<code class="language-sql">SELECT m.*, t.*
FROM memebers as m, telephone as t
INNER JOIN memeberFunctions as mf ON m.id = mf.memeber
INNER JOIN mitgliedTelephone as mt ON m.id = mt.memeber
WHERE mf.function = 32</code>
Nach dem Login kopieren

Diese Abfrage versucht, eine Mischung aus Komma-Notation (zum Verbinden von m und t) und ANSI 1992 JOIN-Syntax (zum Verbinden von mf und mt) zu verwenden. Laut MySQL-Dokumentation wird diese Methode nicht mehr unterstützt. Der Kommaoperator hat jetzt eine niedrigere Priorität als JOIN, was zu Fehlern bei der Operandeninterpretation führt.

Lösung

Um dieses Problem zu beheben, verwenden Sie konsequent die Komma-Schreibweise oder die ANSI 1992 JOIN-Syntax. Für eine bessere Übersichtlichkeit und Zuverlässigkeit wird die Verwendung der JOIN-Syntax empfohlen:

<code class="language-sql">SELECT m.*, t.*
FROM memebers AS m
JOIN telephone AS t ON m.id = t.id
JOIN memeberFunctions AS mf ON m.id = mf.memeber AND mf.function = 32
JOIN mitgliedTelephone AS mt ON m.id = mt.memeber</code>
Nach dem Login kopieren

Notizen

  • Beachten Sie, dass die obige Abfrage ein kartesisches Produkt zwischen m und t ausführt, was zu sehr großen Datensätzen führen kann. Stellen Sie sicher, dass Sie in Ihre Abfrage geeignete Filter einbeziehen.
  • Wenn Sie die Komma-Notation verwenden, achten Sie darauf, den gewünschten Join-Typ anzugeben (z. B. JOIN, LEFT JOIN, RIGHT JOIN). Andernfalls ist die Standardeinstellung eine innere Verbindung, was in manchen Fällen möglicherweise nicht der gewünschte Verbindungstyp ist.

Das obige ist der detaillierte Inhalt vonWarum führt das Mischen von ANSI 1992-Joins und Kommas in MySQL-Abfragen zu Fehlern?. 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