Übung 2: SQL-Abfragen über mehrere Tabellen: Unterschied zwischen den Versionen
Zeile 57: | Zeile 57: | ||
AND B.BandNr = C.BandNr | AND B.BandNr = C.BandNr | ||
AND C.Erscheinungsjahr >= 2012 | AND C.Erscheinungsjahr >= 2012 | ||
+ | </syntaxhighlight> | ||
+ | </popup> | ||
+ | |||
+ | <u>Aufgabe 5:</u><br> | ||
+ | Wer (AusweisNr und Name) ist Mitglied einer "Rock"-Band? | ||
+ | <popup name="Lösung"> | ||
+ | <syntaxhighlight lang="sql"> | ||
+ | SELECT P.AusweisNr, P.Name | ||
+ | FROM PERSON AS P, BAND AS B, ist_mitglied_von AS IMV | ||
+ | WHERE B.Stil = "Rock" | ||
+ | AND B.BandNr = IMV.BandNr | ||
+ | AND IMV.AusweisNr = P.AusweisNr | ||
</syntaxhighlight> | </syntaxhighlight> | ||
</popup> | </popup> |
Version vom 1. April 2014, 14:22 Uhr
Schema:
BAND [ BandNr : INT ; Name : VARCHAR(100) ; Stil : VARCHAR(100) ]
PERSON [ AusweisNr : INT ; Name : VARCHAR(100) ; GebDat : DATE ; Rolle : VARCHAR(50) ]
INSTRUMENT [ Name : VARCHAR(100) ; Baujahr : INT ]
CD [ CDNr : INT ; Titel : VARCHAR(100) ; Erscheinungsjahr : INT ; Album? : BOOLEAN ; BandNr : INT ]
ist_mitglied_von [ AusweisNr : INT ; BandNr : INT]
spielt [ AusweisNr : INT ; Name : VARCHAR(100) ]
Vereinfachtes Klassendiagramm:
Formuliere für nachfolgende Aufgaben die zugehörige SQL-Abfrage!
Aufgabe 1:
Gib eine Übersicht aus, welche Person (Name) welche(s) Instrument(e) spielt!
Aufgabe 2:
Wie lauten die Titel der CDs, die die Band "Kings of Leon" veröffentlicht hat?
Aufgabe 3:
Wie lautet der Name der Band, bei der "Caleb Followill" Mitglied ist?
Aufgabe 4:
Wie lauten die Titel der CDs, die die Band "Foo Fighters" seit dem Jahr 2012 veröffentlicht hat?
Aufgabe 5:
Wer (AusweisNr und Name) ist Mitglied einer "Rock"-Band?