Generalisierung {compl.,overl} < Datenbank-Modelle < Schule < Informatik < Vorhilfe
|
Aufgabe | Ein Unternehmen speichert Adressen (Straße, Hausnr., PLZ, Ort, Land) ab,
wobei eine Adresse einem oder mehreren Adressaten (Name, Tel.-Nr., Fax)
zugeordnet ist. Ein Adressat kann immer nur in zwei Varianten vorkommen:
Einmal als Geschäftspartner, zum andern als Vertreter (Fixum, Provision),
wobei es Vertreter gibt, die auch als Geschäftpartner auftreten können. Von
den Vertretern sind einige Verkaufsleiter (Leitungsprovision), und ein Verkaufsleiter
ist keiner oder einer einzigen bestimmten Region (Name, Einwohnerzahl)
zugeordnet. Eine Region kann aber von keinem, einem oder mehreren
Vertretern betreut werden.
Die Geschäftspartner gibt es nur in zwei Varianten: Als Lieferanten (Aufnahmedatum,
Rabattsatz) oder als Kunden (Geschäftstyp). Ein Lieferant kann
dabei auch Kunde sein. Jeder Kunde kommt seinerseits immer in genau einer
von zwei Varianten vor: als potentieller Kunde oder als wirklicher Kunde
(Aufnahmedatum, Kreditlimit, Rabattsatz). Dabei betreut ein Vertreter keinen
oder mehrere wirkliche Kunden. |
Hallo,
Wie aus der Situationsbeschreibung zu erkennen ist, müssen dort zwei Generalisierungen vom Typ {complete, overlapping} erstellt werden.
Das wären "Adressat" (Oberklasse) -> "Geschäftspartner u. Vertreter" (Unterklassen) und "Geschäftspartner" (Oberklasse) -> "Lieferant u. Kunde" (Unterklassen).Das in UML zu modellieren ist nicht das Problem, aber jedes mal wenn ich versuche das in Tabellenstrukturen umzusetzen, weis ich nicht wie viele Tabellen ich brauche und welche Verbindungen sie zueinander haben müssen, das alles korrekt abläuft (ohne Integritätsfehler, Lücken in den Tabellen usw.). Also wie stelle ich in Tabellenform da, das ein Geschäftspartner , Lieferant ODER Kunde ist, aber ein Lieferant auch Kunde sein kann -> bei disjunkten Klassen ist das nicht so ein Problem.
PS: Mein UML-Diagramm und mein kläglicher Access-Versuch befinden sich als Bild im Anhang
Vielen Dank schon mal im Voraus
Ich habe diese Frage in keinem Forum auf anderen Internetseiten gestellt.
Dateianhänge: Anhang Nr. 1 (Typ: png) [nicht öffentlich] Anhang Nr. 2 (Typ: PNG) [nicht öffentlich]
|
|
|
|
Status: |
(Mitteilung) Reaktion unnötig | Datum: | 17:42 Fr 04.01.2008 | Autor: | matux |
$MATUXTEXT(ueberfaellige_frage)
|
|
|
|