jg10:modellierung10:autovermietung:loesung
Lösung von Aufgabe 3: Autovermietung
Eine Autovermietung hat einen Fuhrpark voller Autos, die zu unterschiedlichen Typen gehören (z.B. BMW i3, VW Passat, …). Sie werden gegen eine - je nach Typ unterschiedliche - tägliche Gebühr vermietet. Das Unternehmen benötigt eine Datenbank, in der die Daten seiner Autos (Kennzeichen, Typ) und seiner Kunden (Rufname, Familienname, Anschrift, Telefnonummer) gespeichert werden sollen. Zudem will es wissen, welcher Kunde wann (von … bis) welches Auto entliehen oder reserviert hat und ob die Gebühr schon bezahlt ist.
- Zeichne das Klassendiagramm.
- Erstelle das Datenbankschema.
Möglichkeit 1: n:m-Relation mit Attributen
Datenbankschema:
- Kundin [id: int, rufname: varchar(80), familienname: varchar(100), strasse: varchar(30), hausnummer: varchar(6), plz: varchar(5), ort: varchar(50), telefonnummer: varchar(40)]
- Typ [id: int, name: varchar(30), tagesgebuehr: decimal(8, 2)]
- Auto [id: int, typ_id: int]
- mietet [kundin_id: int, auto_id: int, von: timestamp, bis: timestamp, bezahlt: boolean]
Möglichkeit 2: extra Tabelle "Mietvorgang"
Datenbankschema:
- Kundin [id: int, rufname: varchar(80), familienname: varchar(100), strasse: varchar(30), hausnummer: varchar(6), plz: varchar(5), ort: varchar(50), telefonnummer: varchar(40)]
- Typ [id: int, name: varchar(30), tagesgebuehr: decimal(8, 2)]
- Auto [id: int, typ_id: int]
- mietvorgang [id: int, kundin_id: int, auto_id: int, von: timestamp, bis: timestamp, bezahlt: boolean]
jg10/modellierung10/autovermietung/loesung.txt · Zuletzt geändert: 2022/10/07 15:18 von Martin Pabst