WHERE – wo sind die Unterabfragen?

Datenbearbeitung in SQL

Mona Khalil

Data Scientist, Greenhouse Software

Was ist eine Unterabfrage?

  • Eine in einer anderen Abfrage verschachtelte Abfrage
SELECT column
FROM (SELECT column
      FROM table) AS subquery;
  • Praktisch für Zwischenumwandlungen
Datenbearbeitung in SQL

Was kann man mit Unterabfragen machen?

  • Können in jedem Teil einer Abfrage vorkommen

    • SELECT, FROM, WHERE, GROUP BY
  • Können verschiedene Infos zurückgeben

    • Skalare Größen (3.14159, -2, 0.001)
    • Eine Liste (id = (12, 25, 392, 401, 939))
    • Eine Tabelle
Datenbearbeitung in SQL

Warum Unterabfragen?

  • Gruppen mit zusammengefassten Werten vergleichen
    • Wie hat Liverpool im Vergleich zum Durchschnitt der englischen Premier League in diesem Jahr abgeschnitten?
  • Daten umgestalten
    • Was ist der höchste monatliche Durchschnitt an geschossenen Toren in der Bundesliga?
  • Daten kombinieren, die nicht zusammengeführt werden können
    • Wie bekommt man den Namen der Heimmannschaft und der Gastmannschaft in eine Tabelle mit den Spielergebnissen?
Datenbearbeitung in SQL

Einfache Unterabfragen

  • Können unabhängig von äußerer Abfrage ausgewertet werden
SELECT home_goal
FROM match
WHERE home_goal > (
    SELECT AVG(home_goal) 
    FROM match);

SELECT AVG(home_goal) FROM match;
1.56091291478423
Datenbearbeitung in SQL

Einfache Unterabfragen

  • Werden nur einmal in der ganzen Anweisung verarbeitet
SELECT home_goal
FROM match
WHERE home_goal > (
    SELECT AVG(home_goal) 
    FROM match);
Datenbearbeitung in SQL

Unterabfragen in der WHERE-Klausel

  • Bei welchen Spielen der Saison 2012/13 wurden mehr Heimtore als im Durchschnitt getroffen?
SELECT AVG(home_goal) FROM match;
1.56091291478423
SELECT date, hometeam_id, awayteam_id, home_goal, away_goal
FROM match
WHERE season = '2012/2013'
      AND home_goal > 1.56091291478423;
Datenbearbeitung in SQL

Unterabfragen in der WHERE-Klausel

  • Bei welchen Spielen der Saison 2012/13 wurden mehr Heimtore als im Durchschnitt getroffen?
SELECT date, hometeam_id, awayteam_id, home_goal, away_goal
FROM match
WHERE season = '2012/2013'
      AND home_goal > (SELECT AVG(home_goal)
                     FROM match);
| date       | hometeam_id | awayteam_id | home_goal | away_goal |
|------------|-------------|-------------|-----------|-----------|
| 2012-07-28 | 9998        | 1773        | 5         | 2         |
| 2012-07-29 | 9987        | 9984        | 3         | 3         |
| 2012-10-05 | 9993        | 9991        | 2         | 2         |
Datenbearbeitung in SQL

Unterabfrage zum Filtern einer Liste mit IN

  • Welche Mannschaften spielen in der polnischen Liga?
SELECT
  team_long_name,
  team_short_name AS abbr
FROM team
WHERE 
  team_api_id IN 
  (SELECT hometeam_id
   FROM match
   WHERE country_id = 15722);
| team_long_name | abbr |
|----------------|------|
| Ruch Chorzów   | CHO  |
| Jagiellonia    | BIA  |
| Lech Poznań    | POZ  |
| P. Warszawa    | PWA  |
| Cracovia       | CKR  |
| Górnik Łęczna  | LEC  |
| Polonia Bytom  | GOR  |
| Zagłębie Lubin | ZAG  |
| Pogoń Szczecin | POG  |
| Widzew Łódź    | WID  |
| Śląsk Wrocław  | SLA  |
Datenbearbeitung in SQL

Lass uns üben!

Datenbearbeitung in SQL

Preparing Video For Download...