SQL-Abfragen über mehrere Tabellen
Schema:
BAND [ BandNr : INT ; Name : VARCHAR(100) ; Stil : VARCHAR(100) ; Gründungsjahr : INT ]
PERSON [ AusweisNr : INT ; Name : VARCHAR(100) ; GebDat : DATE ; Rolle : VARCHAR(50) ]
INSTRUMENT [ INr : INT ; Art : 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 ; INr : INT ]
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) (Art) spielt!
<popup name="Lösung">
SELECT P.Name, I.Art
FROM PERSON AS P, spielt AS S, INSTRUMENT AS I
WHERE P.AusweisNr = S.AusweisNr
AND S.INr = I.INr
</popup>
Aufgabe 2:
Wie lauten die Titel der CDs, die die Band "Kings of Leon" veröffentlicht hat?
<popup name="Lösung">
SELECT C.Titel
FROM BAND AS B, CD AS C
WHERE B.Name = "Kings of Leon"
AND B.BandNr = C.BandNr
</popup>
Aufgabe 3:
Wie lautet der Name der Band, bei der "Caleb Followill" Mitglied ist?
<popup name="Lösung">
SELECT B.Name
FROM BAND AS B, PERSON AS P, ist_mitglied_von AS IMV
WHERE P.Name = "Caleb Followill"
AND B.BandNr = IMV.BandNr
AND P.AusweisNr = IMV.AusweisNr
</popup>
Aufgabe 4:
Wie lauten die Titel der CDs, die die Band "Foo Fighters" seit dem Jahr 2012 veröffentlicht hat?
<popup name="Lösung">
SELECT C.Titel
FROM BAND AS B, CD AS C
WHERE B.Name = "Foo Fighters"
AND B.BandNr = C.BandNr
AND C.Erscheinungsjahr >= 2012
</popup>
Aufgabe 5:
Wer (AusweisNr und Name) ist Mitglied einer "Rock"-Band?
<popup name="Lösung">
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
</popup>
Aufgabe 6:
Welche Instrumente (Name) spielen die Mitglieder der Band "Imagine Dragons"?
<popup name="Lösung">
SELECT I.Name
FROM PERSON AS P, BAND AS B, ist_mitglied_von AS IMV, INSTRUMENT AS I, spielt AS S
WHERE B.Name = "Imagine Dragons"
AND B.BandNr = IMV.BandNr
AND IMV.AusweisNr = P.AusweisNr
AND P.AusweisNr = S.AusweisNr
S.INr = I.INr
</popup>
Aufgabe 7:
Wer (Name) ist Mitglied einer "Metal"-Band, die vor dem Jahr 1990 gegründet wurde?
<popup name="Lösung">
SELECT B.Name
FROM PERSON AS P, BAND AS B, ist_mitglied_von AS IMV
WHERE B.Stil = "Metal"
AND B.Gründungsjahr < 1990
AND B.BandNr = IMV.BandNr
AND IMV.AusweisNr = P.AusweisNr
</popup>
