Korrelierte verschachtelte Abfragen

Datengestützte Entscheidungsfindung in SQL

Bart Baesens

Professor Data Science and Analytics

Korrelierte Abfragen

  • Bedingung in der WHERE-Klausel der inneren Abfrage
  • Verweist auf eine Spalte einer Tabelle in der äußeren Abfrage
Datengestützte Entscheidungsfindung in SQL

Beispiel für korrelierte Abfrage

  • Anzahl der ausgeliehenen Filme: größer als 5
    SELECT *
    FROM movies as m
    WHERE 5 < 
      (SELECT COUNT(*)
      FROM renting as r
      WHERE r.movie_id=m.movie_id);
    
Datengestützte Entscheidungsfindung in SQL

Innere Abfrage auswerten

SELECT COUNT(*)
FROM renting as r
WHERE r.movie_id = 1;
| count |
|-------|
| 8     |
Datengestützte Entscheidungsfindung in SQL

Äußere Abfrage auswerten

Anzahl der ausgeliehenen Filme: größer als 5

SELECT *
FROM movies as m
WHERE 5 < 
    (SELECT COUNT(*)
    FROM renting as r
    WHERE r.movie_id = m.movie_id);
| movie_id | title                 | genre  | runtime | year_of_release | renting_price |
|----------|-----------------------|--------|---------|-----------------|---------------|
| 1        | One Night at McCool's | Comedy | 93      | 2001            | 2.09          |
| 2        | Swordfish             | Drama  | 99      | 2001            | 2.19          |
Datengestützte Entscheidungsfindung in SQL

Weniger als 5 Filme ausgeliehen

Filme auswählen, die weniger als 5 Mal ausgeliehen wurden

SELECT *
FROM movies as m
WHERE 5 > 
    (SELECT COUNT(*)
    FROM renting as r
    WHERE r.movie_id = m.movie_id);
| movie_id | title           | genre              | runtime | year_of_release | renting_price |
|----------|-----------------|--------------------|---------|-----------------|---------------|
| 17       | The Human Stain | Mystery & Suspense | 106     | 2003            | 1.99          |
| 20       | Love Actually   | Comedy             | 135     | 2003            | 2.29          |
Datengestützte Entscheidungsfindung in SQL

Lass uns üben!

Datengestützte Entscheidungsfindung in SQL

Preparing Video For Download...