Heim >Datenbank >MySQL-Tutorial >MySQL-Abfrageverbindung
Einführung in die MySQL-Abfrageverbindung
Bei der Datenbankverwaltung ist die Abfrageverbindung ein sehr wichtiger Bestandteil. Unter „Join“ versteht man den Prozess des Zusammenführens von zwei oder mehr Tabellen basierend auf der Beziehung zwischen ihnen, um die Datenabfrage abzuschließen. In MySQL können wir Abfrageverbindungen mithilfe der JOIN-Anweisung implementieren. Dieser Artikel bietet eine ausführliche Einführung in die Verwendung von MySQL-Abfrageverbindungen.
Klassifizierung von MySQL-Abfrageverbindungen
MySQL-Abfrageverbindungen werden hauptsächlich in drei Kategorien unterteilt: Inner Joins, Outer Joins und Cross Joins.
Inner Join bedeutet, dass zwischen Datensätzen in zwei oder mehr Tabellen eine entsprechende Beziehung besteht. Diese Beziehung kann durch Primärschlüssel und Fremdschlüssel dargestellt werden. Inner Joins geben Ergebnisse zurück, indem sie dieselben Datensätze beibehalten. Das heißt, Abfrageergebnisse werden nur zurückgegeben, wenn in beiden Tabellen übereinstimmende Datensätze vorhanden sind.
Die Syntax des inneren Joins lautet wie folgt:
SELECT col1, col2, ...
FROM table1
INNER JOIN table2
ON table1.column1 = table2.column2;
Daunter col1, col2, ... zurückzugeben sind: Spalte table1 und table2 sind die abzufragenden Tabellen, Column1 und Column2 sind die Spalten, die die Tabellen verbinden.
Outer Joins werden in Left Joins und Right Joins unterteilt. Diese Art von Join bedeutet, dass bei der Verbindung von zwei oder mehr Tabellen alle Datensätze einbezogen werden, auch wenn eine der Tabellen nicht mit passenden Datensätzen verknüpft ist von einem anderen Tisch.
Left-Join: Left-Join bedeutet, dass die linke Tabelle alle Datensätze abruft, während die rechte Tabelle nur passende Datensätze abruft. Wenn zwischen der linken und der rechten Tabelle keine übereinstimmenden Datensätze vorhanden sind, gibt die rechte Tabelle einen NULL-Wert zurück.
Die Syntax des linken Joins lautet wie folgt:
SELECT col1, col2, ...
FROM table1
LEFT JOIN table2
ON table1.column1 = table2.column2;
Right Join: Right Join ähnelt dem Left Join , außer auf der linken Seite. Die Rollen der Tabelle und der Tabelle auf der rechten Seite sind vertauscht.
Die Syntax des rechten Joins lautet wie folgt:
SELECT col1, col2, ...
FROM table1
RIGHT JOIN table2
ON table1.column1 = table2.column2;
Hinweis: In MySQL gibt es auch ein FULL OUTER für äußere Verknüpfungen JOIN (vollständige äußere Verknüpfung), MySQL unterstützt dies jedoch nicht. Daher können wir über die UNION-Anweisung einen vollständigen Outer-Join simulieren.
Cross Join bezieht sich auf einen Join ohne Join-Bedingungen zwischen zwei oder mehr Tabellen. Einfach ausgedrückt ermöglichen Cross-Joins die Abfrage aller möglichen Kombinationen.
Die Syntax des Cross-Joins lautet wie folgt:
SELECT col1, col2, ...
FROM table1
CROSS JOIN table2;
Unter diesen sind col1, col2, ... die zurückzugebenden Spalten; table2 soll als Oberfläche abgefragt werden.
Anwendungsbeispiele für die MySQL-Abfrageverbindung
Lassen Sie uns nun die Verwendung der MySQL-Abfrageverbindung anhand einiger praktischer Beispiele verstehen.
Beispiel 1: Innerer Join
Angenommen, wir haben zwei Tabellen „Schüler“ und „Kurs“. Ihre Spalten und Inhalte lauten wie folgt:
Studententabelle:
ID | Name | Alter |
---|---|---|
1 | Jack | 18 |
2 | Tom | 19 |
3 | Jerry | 20 |
4 | Bob | 18 |
Kurstabelle:
Kurs-ID | Kursname | Studenten-ID |
---|---|---|
1 | Mathe | 1 |
2 | Englisch | 2 |
Wissenschaft | 2 | |
Geschichte | 3 |
FROM student
INNER JOIN course
ON student .id = course.student_id;
Kursname | |
---|---|
Math | |
Englisch | |
Wissenschaft | |
Geschichte |
FROM student
LEFT JOIN course
ON student.id = course.student_id;
Kursname | |
---|---|
Mathe | |
Englisch | |
Naturwissenschaften | |
Geschichte | |
NULL |
FROM student
RIGHT JOIN course
ON student.id = course.student_id;
Name | erryGeschichte | ||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Geographie | |||||||||||||||||||||
Name | |
---|---|
A | |
B | #🎜 🎜 #3 |
CROSS JOIN table1 t2;
Diese Abfrage gibt die folgenden Ergebnisse zurück: #🎜🎜 #
Name
#🎜🎜 #A | |
---|---|
A | B |
B | |
C | |
C | |
C#🎜 🎜##🎜🎜 #C | |
Fazit | Die MySQL-Abfrageverbindung ist ein wichtiger Teil der SQL-Sprache und kann uns dabei helfen, Daten abzufragen, die Beziehungen enthalten. In diesem Artikel stellen wir die Syntax und Anwendungsbeispiele der vier Arten von Joins vor: Inner Join, Left Join, Right Join und Cross Join. Ich hoffe, dieser Artikel hilft Ihnen bei der Verwendung der MySQL-Abfrageverbindung. |
Das obige ist der detaillierte Inhalt vonMySQL-Abfrageverbindung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!