Filtern deiner CASE-Anweisung
Erstellen wir eine Liste der Spiele, die die italienische Mannschaft von Bologna gewonnen hat! Es gibt eine ganze Reihe weiterer Mannschaften in den beiden Tabellen. Um eine brauchbare Abfrage zu erstellen, musst du deine CASE-Anweisung als Filter in der WHERE-Klausel verwenden.
CASE-Anweisungen ermöglichen es dir, Daten zu kategorisieren, die dich interessieren – und Daten auszuschließen, an denen du nicht interessiert bist. Dazu kannst du eine CASE-Anweisung als Filter in der WHERE-Anweisung verwenden, um Ergebnisse zu entfernen, die du nicht sehen willst.
Dafür kannst du wie folgt vorgehen:
SELECT *
FROM table
WHERE
CASE WHEN a > 5 THEN 'Keep'
WHEN a <= 5 THEN 'Exclude' END = 'Keep';
Im Grunde kannst du die CASE-Anweisung wie jede andere Spalte in deiner Datenbank als Filterspalte verwenden. Der einzige Unterschied ist, dass du die Anweisung in WHERE nicht mit einem Alias versiehst.
Diese Übung ist Teil des Kurses
Datenbearbeitung in SQL
Anleitung zur Übung
- Verwende die
CASE-Anweisung in derWHERE-Klausel, um zu filtern, wohometeam_idgleich9857ist und die Heimtorzahl die Gasttorzahl übersteigt. - Verwende die
CASE-Anweisung in derWHERE-Klausel, um zu filtern, woawayteam_idgleich9857ist und mehr Gasttore als Heimtore gefallen sind. - Schließe die
CASE-Anweisung, indem du Spiele ausschließt, die Bologna nicht gewonnen hat.
Interaktive Übung
Vervollständige den Beispielcode, um diese Übung erfolgreich abzuschließen.
SELECT
season,
date,
home_goal,
away_goal
FROM matches_italy
WHERE
-- Find games where home_goal is more than away_goal
___ ___ hometeam_id = 9857 ___ home_goal ___ away_goal ___ 'Bologna Win'
-- Find games where away_goal is more than home_goal
___ awayteam_id = 9857 ___ away_goal ___ home_goal ___ 'Bologna Win'
-- Exclude games not won by Bologna
___ IS NOT ___;