Subqueries

Aus FI-Wiki
Version vom 29. Oktober 2025, 08:44 Uhr von Moettke (Diskussion | Beiträge) (Die Seite wurde neu angelegt: „== Subqueries in SQL == Subqueries (Unterabfragen) sind SQL-Abfragen, die innerhalb einer anderen Abfrage eingebettet sind. Sie liefern Zwischenergebnisse, die in der äußeren Abfrage verwendet werden. === Arten von Subqueries === * '''Skalare Subquery''': Gibt genau einen Wert zurück * '''Mehrzeilige Subquery''': Gibt eine Liste von Werten zurück * '''Korrelierte Subquery''': Bezieht sich auf eine Tabelle der äußeren Abfrage === Beispieltabellen…“)
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)

Subqueries in SQL

Subqueries (Unterabfragen) sind SQL-Abfragen, die innerhalb einer anderen Abfrage eingebettet sind. Sie liefern Zwischenergebnisse, die in der äußeren Abfrage verwendet werden.

Arten von Subqueries

  • Skalare Subquery: Gibt genau einen Wert zurück
  • Mehrzeilige Subquery: Gibt eine Liste von Werten zurück
  • Korrelierte Subquery: Bezieht sich auf eine Tabelle der äußeren Abfrage

Beispieltabellen

Kunde(kundennr, name, land)
Bestellung(bestellnr, kundennr, betrag)

1. Skalare Subquery

SELECT name
FROM kunde
WHERE kundennr = (
    SELECT kundennr
    FROM bestellung
    WHERE betrag = (SELECT MAX(betrag) FROM bestellung)
);

Gibt den Namen des Kunden mit der höchsten Bestellung zurück.

2. Mehrzeilige Subquery mit IN

SELECT name
FROM kunde
WHERE kundennr IN (
    SELECT kundennr
    FROM bestellung
    WHERE betrag > 1000
);

Gibt alle Kunden zurück, die Bestellungen über 1000 haben.

3. Korrelierte Subquery

SELECT name
FROM kunde k
WHERE EXISTS (
    SELECT *
    FROM bestellung b
    WHERE b.kundennr = k.kundennr AND b.betrag > 1000
);

Funktioniert zeilenweise: Gibt Kunden zurück, für die es mindestens eine große Bestellung gibt.

Vergleich der Subquery-Arten

  • Skalare Subquery: 1 Zeile, 1 Spalte (z. B. MAX, COUNT)
  • Mehrzeilige Subquery: mehrere Zeilen (z. B. für IN oder NOT IN)
  • Korrelierte Subquery: wird für jede Zeile der äußeren Abfrage neu ausgeführt

Fazit

  • Skalare Subquery: liefert genau einen Wert
  • Mehrzeilige Subquery: liefert eine Liste von Werten
  • Korrelierte Subquery: ist abhängig von der äußeren Zeile und flexibler, aber ggf. langsamer