single
Left-, Right- und Inner-Joins
Swipe um das Menü anzuzeigen
Der Online-Shop hat mehr Produkte bei einem Lieferanten bestellt, da der Lagerbestand zur Neige ging. Das bedeutet, wir haben etwas freie Zeit, bis die Lieferung eintrifft.
Dies ist die Gelegenheit, etwas Neues zu lernen! Bisher hast du den Standard-JOIN in SQL verwendet, aber es gibt noch andere Arten von Joins, die du nutzen kannst.
Hier sind die 4 Haupttypen von Tabellen-Joins:
INNER JOIN: Gibt Zeilen mit übereinstimmenden Werten in beiden Tabellen zurück. Dies entspricht dem Standard-JOIN, den du bisher verwendet hast:
LEFT JOIN: Gibt alle Zeilen aus der linken Tabelle und die passenden Zeilen aus der rechten Tabelle zurück. Wenn es keine Übereinstimmungen gibt, wird NULL für die rechte Tabelle zurückgegeben:
RIGHT JOIN: Gibt alle Zeilen aus der rechten Tabelle und die übereinstimmenden Zeilen aus der linken Tabelle zurück. Wenn keine Übereinstimmungen vorhanden sind, wird NULL für die linke Tabelle zurückgegeben:
FULL JOIN: Gibt alle Zeilen aus beiden Tabellen zurück. Wenn keine Übereinstimmung vorhanden ist, wird NULL für die fehlenden Werte aus der anderen Tabelle zurückgegeben:
Vor der Arbeit mit diesen Joins sieh dir die beiden Tabellen an, mit denen du arbeiten wirst. Sie enthalten Details zu Kursen und den eingeschriebenen Studierenden.
courses:
enrollments:
Die Syntax für die Verwendung dieser Join-Typen ist tatsächlich einfach. Anstelle des bekannten JOIN oder INNER JOIN geben Sie einfach LEFT JOIN oder einen anderen Typ von JOIN an:
SELECT table1.column, table2.column
FROM table1 -- this is the LEFT table
LEFT JOIN table 2 -- this is the RIGHT table
ON table1.common_column = table2.common_column
Wischen, um mit dem Codieren zu beginnen
Schreiben Sie eine Abfrage, um eine Liste aller Kurse und der eingeschriebenen Studierenden abzurufen, einschließlich der Kurse ohne registrierte Studierende.
Sie müssen die folgenden Spalten in dieser Reihenfolge abrufen:
courses.course_id,
courses.course_name,
courses.description,
enrollments.student_name,
enrollments.enrollment_date
Verwenden Sie den passenden Typ von JOIN, um diese Aufgabe zu lösen!
Kurzanleitung
- Abrufen der Spalten
courses.course_id,courses.course_name,courses.description,enrollments.student_nameundenrollments.enrollment_dateaus der Tabellecourses. - Verwenden Sie einen LEFT JOIN, um die Tabelle
enrollmentszu verbinden. - Die gemeinsame Spalte beider Tabellen ist
courses.course_id = enrollments.course_id.
Lösung
Danke für Ihr Feedback!
single
Fragen Sie AI
Fragen Sie AI
Fragen Sie alles oder probieren Sie eine der vorgeschlagenen Fragen, um unser Gespräch zu beginnen