Heim >Datenbank >MySQL-Tutorial >Wie kann ich in MySQL zweimal derselben Tabelle beitreten?

Wie kann ich in MySQL zweimal derselben Tabelle beitreten?

Barbara Streisand
Barbara StreisandOriginal
2024-12-13 00:36:10848Durchsuche

How to Join the Same Table Twice in MySQL?

So führen Sie mehrere Join-Vorgänge für dieselbe Tabelle in MySQL durch

Wenn Sie mit mehreren Tabellen arbeiten, kann es erforderlich sein, diese zu verbinden mehrere Instanzen derselben Tabelle. In MySQL kann dies durch mehrere LEFT JOIN-Anweisungen erreicht werden.

Stellen Sie sich das folgende Szenario vor: Sie haben zwei Tabellen, „Domänen“ und „Bewertungen“, mit den folgenden Spalten:

  • Domänen: dom_id, dom_url
  • Bewertungen: rev_id, rev_dom_from, rev_dom_for

Um beide mit jeder Bewertung verknüpften Domänennamen (aus der Tabelle „Domänen“) anzuzeigen, benötigen Sie Folgendes um zwei LEFT JOINs für die Tabelle „Domänen“ auszuführen. So würde die Abfrage aussehen:

SELECT toD.dom_url AS ToURL, 
    fromD.dom_url AS FromURL, 
    rvw.*

FROM reviews AS rvw

LEFT JOIN domain AS toD 
    ON toD.Dom_ID = rvw.rev_dom_for

LEFT JOIN domain AS fromD 
    ON fromD.Dom_ID = rvw.rev_dom_from

Durch Aliasnamen der zweiten „Domains“-Tabelle als „toD“ und „fromD“ können Sie angeben, mit welcher Spalte verknüpft werden soll und welcher Domainname abgerufen werden soll. In der SELECT-Liste können Sie dann mithilfe der entsprechenden Tabellenaliase auf die gewünschten Domänennamen verweisen.

Zusammenfassend lässt sich sagen, dass Sie zum zweimaligen Verbinden derselben Tabelle in MySQL einfach mehrere LEFT JOIN-Anweisungen mit unterschiedlichen Tabellenaliasen verwenden müssen. Dadurch können Sie innerhalb einer einzigen Abfrage auf mehrere Spalten derselben Tabelle zugreifen.

Das obige ist der detaillierte Inhalt vonWie kann ich in MySQL zweimal derselben Tabelle beitreten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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