SQL-Joins Meistern: Inner, Left, Right & Full Explained (2024)

SQL-Joins Meistern: Inner, Left, Right & Full Explained (1)

SQL (Structured Query Language) ist die standardisierte Sprache für das Management relationaler Datenbanken. Einer der entscheidenden Aspekte bei der Arbeit mit relationalen Datenbanken ist die effiziente Extraktion von Daten aus verschiedenen Tabellen. Hier kommen SQL Joins ins Spiel. SQL Joins ermöglichen es, Daten aus zwei oder mehr Tabellen auf Basis einer verwandten Spalte zwischen ihnen zu kombinieren. Dieser Artikel bietet einen umfassenden Überblick über verschiedene Joins in SQL, um Ihnen zu helfen, Daten effizient und effektiv zu abrufen.

1. INNER JOIN

Definition

Der INNER JOIN ist einer der am häufigsten verwendeten Joins in SQL. Er gibt alle Zeilen zurück, wenn es mindestens eine Übereinstimmung in beiden Tabellen gibt.

Beispiel

SELECT employees.name, departments.nameFROM employeesINNER JOIN departments ON employees.department_id = departments.id;

Hier werden alle Mitarbeiter und ihre entsprechenden Abteilungsnamen aus den Tabellen employees und departments zurückgegeben, vorausgesetzt, es gibt eine Übereinstimmung zwischen den department_id und id Spalten.

2. LEFT (OUTER) JOIN

Definition

Der LEFT JOIN oder LEFT OUTER JOIN gibt alle Zeilen aus der linken Tabelle und die übereinstimmenden Zeilen aus der rechten Tabelle zurück. Wenn keine Übereinstimmung vorliegt, sind die Resultate aus der rechten Tabelle NULL.

Beispiel

SELECT students.name, courses.nameFROM studentsLEFT JOIN course_enrollments ON students.id = course_enrollments.student_id;

Dieses Beispiel gibt alle Studenten und die Kurse zurück, für die sie eingeschrieben sind – auch die Studenten, die für keinen Kurs eingeschrieben sind.

3. RIGHT (OUTER) JOIN

Definition

Der RIGHT JOIN oder RIGHT OUTER JOIN gibt alle Zeilen aus der rechten Tabelle und die übereinstimmenden Zeilen aus der linken Tabelle zurück. Wenn keine Übereinstimmung vorhanden ist, ist das Ergebnis aus der linken Tabelle NULL.

Beispiel

SELECT orders.id, customers.nameFROM ordersRIGHT JOIN customers ON orders.customer_id = customers.id;

Hier werden alle Kunden und ihre Bestellungen zurückgegeben, auch Kunden, die noch nichts bestellt haben.

4. FULL (OUTER) JOIN

Definition

Der FULL JOIN oder FULL OUTER JOIN gibt alle Zeilen zurück, wenn es eine Übereinstimmung in einer der Tabellen gibt.

Beispiel

SELECT students.name, courses.nameFROM studentsFULL JOIN course_enrollments ON students.id = course_enrollments.student_id;

Dieses Beispiel gibt alle Studenten und alle Kursanmeldungen zurück, auch wenn keine Übereinstimmung vorhanden ist.

5. CROSS JOIN

Definition

CROSS JOIN produziert das kartesische Produkt zweier Tabellen, d.h., es gibt alle möglichen Kombinationen von Zeilen aus den beiden Tabellen zurück.

Beispiel

SELECT colors.name, sizes.nameFROM colorsCROSS JOIN sizes;

Hier werden alle möglichen Kombinationen von Farben und Größen zurückgegeben.

6. SELF JOIN

Definition

Ein SELF JOIN ist ein regulärer Join, aber die Tabelle wird mit sich selbst verbunden.

Beispiel

SELECT a.name AS employee_name, b.name AS manager_nameFROM employees a, employees bWHERE a.manager_id = b.id;

In diesem Beispiel werden Mitarbeiter und ihre Manager aus derselben Tabelle employees abgerufen.

Joins sind ein unerlässliches Werkzeug bei der Arbeit mit relationalen Datenbanken, da sie eine flexible und effiziente Datenextraktion aus mehreren Tabellen ermöglichen. Durch das Verständnis der verschiedenen Typen von Joins und ihrer Anwendung können Sie komplexe Abfragen erstellen und den Wert Ihrer Daten maximieren. Jeder Join-Typ hat seine speziellen Anwendungsfälle und kann unter den richtigen Umständen unschätzbare Einsichten bieten.

Inhalt dieser Seite

Gibt es unterschiede in der Schreibweise bei den Joins?

Ja, es gibt verschiedene Weisen, wie Joins in SQL geschrieben werden können, insbesondere wenn man die Syntax von ANSI-SQL und die von älteren SQL-Dialekten betrachtet. Hier sind zwei Hauptansätze, wie Joins formuliert werden können:

1. ANSI SQL-92 Syntax

In dieser älteren Syntax werden die zu verbindenden Tabellen im FROM-Teil der Abfrage durch Kommata getrennt aufgelistet, und die Verbindungsbedingung wird im WHERE-Teil der Abfrage spezifiziert.

Beispiel für INNER JOIN:

SELECT employees.name, departments.nameFROM employees, departmentsWHERE employees.department_id = departments.id;

2. ANSI SQL-99 Syntax

Diese neuere Syntax ist in der SQL-Community allgemein bevorzugt, weil sie klarer und leichter zu lesen ist, insbesondere bei komplexen Abfragen mit mehreren Joins. Hier wird die JOIN-Operation explizit im FROM-Teil der Abfrage mithilfe des JOIN-Schlüsselworts aufgeführt, und die Verbindungsbedingung wird im ON-Teil spezifiziert.

Beispiel für INNER JOIN:

SELECT employees.name, departments.nameFROM employeesINNER JOIN departments ON employees.department_id = departments.id;

Beide Syntaxformen sind in den meisten relationalen Datenbanksystemen gültig, aber der zweite Ansatz (ANSI SQL-99) wird oft als besser lesbar und verständlicher angesehen, besonders wenn es um komplexe Abfragen geht. Darüber hinaus erlaubt die neuere Syntax eine klarere Trennung zwischen den Verbindungsbedingungen (ON) und den Filterbedingungen (WHERE), was die Abfrage oft leichter verständlich macht.

Es ist wichtig anzumerken, dass, obwohl beide Syntaxformen weit verbreitet unterstützt werden, es dennoch empfehlenswert ist, sich an den neueren Standard (ANSI SQL-99) zu halten, weil er mehr Funktionalitäten (wie z.B. verschiedene Arten von OUTER JOINS) und eine bessere Lesbarkeit bietet.

Gibt es noch andere Möglichkeiten im SQL um Daten miteinander zu selektieren?

Ja, es gibt auch andere Techniken, um Daten aus verschiedenen Tabellen in SQL zu kombinieren, auch wenn Joins die am häufigsten verwendete Methode sind. Hier sind einige weitere Methoden:

1. Subqueries

Eine Subquery (Unterabfrage) wird innerhalb einer übergeordneten Abfrage verwendet, um Daten zu holen, die dann in der Hauptabfrage verwendet werden. Subqueries können in verschiedenen Teilen der SQL-Abfrage wie SELECT, FROM und WHERE-Klausel verwendet werden.

Beispiel:

SELECT name,(SELECT name FROM departments WHERE id = employees.department_id) AS department_nameFROM employees;

2. UNION und UNION ALL

UNION und UNION ALL werden dazu verwendet, die Ergebnisse von zwei oder mehr SELECT-Anweisungen zu kombinieren. Dabei ist zu beachten, dass UNION Duplikate entfernt, während UNION ALL alle Ergebnisse zurückgibt, auch Duplikate.

Beispiel:

SELECT name FROM employeesUNIONSELECT name FROM contractors;

3. Correlated Subqueries

Eine korrelierte Unterabfrage ist eine Unterabfrage, die eine Beziehung zwischen der inneren Abfrage und der äußeren Abfrage hat. Die innere Abfrage ist von der äußeren Abfrage abhängig und wird für jede Zeile der äußeren Abfrage neu berechnet.

Beispiel:

SELECT e.name, e.salaryFROM employees eWHERE e.salary > (SELECT AVG(salary)FROM employeesWHERE department_id = e.department_id);

4. Verwenden von Temporären Tabellen

Manchmal wird eine temporäre Tabelle erstellt und verwendet, um Daten zu speichern, die dann mit einer anderen Tabelle verbunden werden.

Beispiel:

CREATE TEMPORARY TABLE temp_employees ASSELECT * FROM employees WHERE salary > 50000;SELECT * FROM temp_employeesJOIN departments ON temp_employees.department_id = departments.id;

5. Verwenden von abgeleiteten Tabellen

Eine abgeleitete Tabelle ist eine Tabelle, der innerhalb einer SELECT-Anweisung erzeugt wird. Man kann abgeleitete Tabellen in der FROM-Klausel verwenden, um sie mit anderen Tabellen zu verbinden.

Beispiel:

SELECT e.name, d.nameFROM (SELECT * FROM employees WHERE salary > 50000) AS eJOIN departments d ON e.department_id = d.id;

Jede dieser Techniken hat ihre eigenen Vor- und Nachteile sowie Anwendungsgebiete, abhängig von den spezifischen Anforderungen der Abfrage und der Datenbankstruktur. Es ist auch üblich, mehrere dieser Techniken in Kombination in komplexeren Abfragen zu verwenden.

Wie hat dir der Artikel gefallen?

Vielen Dank für dein Feedback!

Ähnliche Beiträge:

Performance Überwachung bei MS SQL Server über System TablesSQL Server OpenqueryIndizes in DatenbankenUnterschied zwischen Tabellen und SichtenData Catalog -Der Wert von Daten in der heutigen WirtschaftSQL Beispiele für die ETL Überwachung sowie Datenintegrität und Datenqualität

SQL-Joins Meistern: Inner, Left, Right & Full Explained (2024)

References

Top Articles
Latest Posts
Article information

Author: Aracelis Kilback

Last Updated:

Views: 5990

Rating: 4.3 / 5 (44 voted)

Reviews: 83% of readers found this page helpful

Author information

Name: Aracelis Kilback

Birthday: 1994-11-22

Address: Apt. 895 30151 Green Plain, Lake Mariela, RI 98141

Phone: +5992291857476

Job: Legal Officer

Hobby: LARPing, role-playing games, Slacklining, Reading, Inline skating, Brazilian jiu-jitsu, Dance

Introduction: My name is Aracelis Kilback, I am a nice, gentle, agreeable, joyous, attractive, combative, gifted person who loves writing and wants to share my knowledge and understanding with you.