Abfragen mit EXISTS

Datengestützte Entscheidungsfindung in SQL

Irene Ortner

Data Scientist at Applied Statistics

EXISTS

  • Sonderfall einer korrelierten verschachtelten Abfrage
  • Stellt fest, ob Ergebnis einer korrelierten verschachtelten Abfrage leer ist
  • Gibt zurück: WAHR oder FALSCH
  • WAHR = nicht leer -> Zeile der äußeren Abfrage ist ausgewählt
  • FALSCH = leer
  • In SELECT-Klausel angegebene Spalten werden nicht berücksichtigt – SELECT * verwenden
Datengestützte Entscheidungsfindung in SQL

Filme mit mindestens einer Bewertung

SELECT *
FROM movies AS m
WHERE EXISTS
    (SELECT *
     FROM renting AS r
     WHERE rating IS NOT NULL 
     AND r.movie_id = m.movie_id);
Datengestützte Entscheidungsfindung in SQL

Filme mit mindestens einer Bewertung

SELECT *
FROM renting AS r
WHERE rating IS NOT NULL 
AND r.movie_id = 11;
| renting_id | customer_id | movie_id | rating | renting_price |
|------- ----|-------------|----------|--------|---------------|
Datengestützte Entscheidungsfindung in SQL

Filme mit mindestens einer Bewertung

SELECT *
FROM renting AS r
WHERE rating IS NOT NULL 
AND r.movie_id = 1;
| renting_id | customer_id | movie_id | rating | renting_price |
|------------|-------------|----------|--------|---------------|
| 71         | 111         | 1        | 5      | 2018-07-21    |
| 170        | 36          | 1        | 10     | 2018-10-18    |
Datengestützte Entscheidungsfindung in SQL

EXISTS-Abfrage mit Ergebnis

SELECT *
FROM movies AS m
WHERE EXISTS
    (SELECT *
     FROM renting AS r
     WHERE rating IS NOT NULL 
     AND 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

NOT EXISTS

  • WAHR = Tabelle ist leer -> Zeile der äußeren Abfrage wird ausgewählt
SELECT *
FROM movies AS m
WHERE NOT EXISTS
    (SELECT *
     FROM renting AS r
     WHERE rating IS NOT NULL 
     AND r.movie_id = m.movie_id);
| movie_id | title    | genre  | runtime | year_of_release | renting_price |
|----------|----------|--------|---------|-----------------|---------------|
| 11       | Showtime | Comedy | 95      | 2002            | 1.79          |
Datengestützte Entscheidungsfindung in SQL

Lass uns üben!

Datengestützte Entscheidungsfindung in SQL

Preparing Video For Download...