Modellierung eines trivialen Web-Shops

Status
Nicht offen für weitere Antworten.

Mork

Mitglied
Hallo Zusammen,

hätte mal ein paar Fragen bezüglich der Modellierung eines trivialen Web-Shops
attachment.php


1. Welchen Assoziationstypen würdest ihr zwischen Bestellung und Posten wählen?
* Für die Aggregation spricht, dass eine Bestellung aus mehreren Posten besteht.
* Für die Komposition spricht, dass ein Posten nicht ohne dazugehörige Bestellung existiert.

2. Wo würde man eine Methode wie getProdukteDieNochNieBestelltWurden() hin tun?
* Ich würde sagen, man sucht Produkte, deshalb müsste sie bei Produkte rein. Auf der anderen Seite bezieht sich "noch nie bestellt" auf die Tatsache, welches Produkt noch nie ein Posten war, deshalb könnte man es auch zu Posten tun.

3. Wo macht man die Mehrwertsteuer hin?
* man kommt sofort auf die Idee, es als Subklasse von Produkte zu modellieren, zb Schreibwaren haben x% MwSt. Nun stellt man sich aber eine Filiale vor mit Zeitschriften und Essenverkauf. Abhängig wo man die Speise zu sich nimmt, muss man 7%(Außer-Haus) oder 19% (im Haus) zahlen. Ich tendiere also dazu die MwSt an Posten zu machen und sie über einen regelbasierten Algorithmus zuweisen, sobald jemand ein Produkt einer Bestellung zuweist.

Was meint ihr? Vielen Dank schonmal :)
 

hdi

Top Contributor
ohne jeden Anspruch auf "Richtigkeit", aber ich würde sagen:

zu 2) Ein Produkt sollte über sich selbst nicht speichern, ob es bestellt wurde oder nicht. Dadurch ist ein Produkt nämlich nicht definiert, und was machst du wenn du vllt irgendwann mal meherere Standorte hast und nun wissen willst, ob das Produkt schon in Standort A oder B bestellt wurde. Eine Liste von Standorten im Produkt? Find ich da fehl am Platz.

zu 3) ich würde im Produkt nur den Netto-Wert speichern & dann eine unabhängige Hilfsklasse erstellen, mit einer Methode:

public double calculatePrice(Produkt p, double steuern)

Und aufrufen tut das dann die Filiale, mit passenden Steuern, da stimme ich dir zu.

und zu 1) keine Angaben xD
 
M

maki

Gast
1. Posten ist imho eine Komposition.

2. Wo steckst du deine DB Anfragen rein? Daos? Repositories? Dann gehört dort auch die getProdukteDieNochNieBestelltWurden Methode hin. Die Namen bitte auf Englisch, sonst führt das zu schlimmsten Denglisch.

3. Hört sich für mich nach einem Fall für das Strategy Pattern an.
 

ARadauer

Top Contributor
2. das mach sicher kein Produkt... sondern irgend ein DAO oder ein Service

3. Das Produkt hat seinen Steuersatz als Wert gespeichert.... wieso sollte man da vererben?
 

Mork

Mitglied
@ARadauer

Mehrwertsteuer ist u.a. abhängig von der Produktgruppe. Wenn ich Zeitschriften und Unterhaltungselektronik mit unterschiedlichen MwSt habe, dann muss ich bei einer Änderung des Satzes nur die Sätze der Produktgruppen ändern und nicht über jedes Produkt einzeln gehen und die MwSt anpassen.

@ andere

3. Die separate Bestimmung der MwSt hört sich für mich auch am plausibelsten an.

2. In dem konzeptuellen Klassendiagramm habe ich keine DAOs oder Services. Kann man also sagen das diese Methode in ein DAO oder Service muss und direkt in der Posten oder Produktklasse nichts zu suchen hat? Auch in der konzeptuellen Modellierung nicht?

Wenn man es streng objektrorientiert nimmt, dann ist die Methode getProdukteDieNochNieBestelltWurden weder von einem Produkt-Objekt, noch von einem Posten-Objekt oder einem anderen Objekt abhängig. Das wäre eine Argumentation sie unbedingt in ein DAO oder Service auszulagern.
 
M

maki

Gast
2. In dem konzeptuellen Klassendiagramm habe ich keine DAOs oder Services. Kann man also sagen das diese Methode in ein DAO oder Service muss und direkt in der Posten oder Produktklasse nichts zu suchen hat? Auch in der konzeptuellen Modellierung nicht?
(Domain-)Services hat man auf jedenfall in konzeptionellen Modellen, und anstatt DAOs nimmt man da Repositories, siehe DDD.
 
M

maki

Gast
Wie man was darstellt?
Klassendiagramme? ;) Das machst du doch bereits...

Einfach eine Assoziation erstellen imho.
Ist doch nur wichtig dass du bestimmtes Verhalten/Funktionen an Klassen zuordnest.
 

Mork

Mitglied
Ja klar Klassendiagram, aber wie man es im Klassendiagram darstellt. Einfach eine Klasse die ich ProductDAO nenne? ProductDAO wäre dann ohne Assoziationen zu anderen Klassen. Oder solltest man eine gestrichelte Linie wählen um eine Dependency zwischen Product und ProductDAO zu signalisieren.

Die andere Frage: ist es dann ProductDAO oder PostenDAO? Ich würde nach wie vor sagen, dass ich es eher bei ProductDAO sehe.
 
M

maki

Gast
Würde das auch im ProductDao sehen, besser im ProductRepository ;)

Wie du die Assoziaten darstellst, liegt imho hauptsächlich daran was du damit aussagen willst.
Die gestrichelte "use" Notation würde doch reichen, oder nicht?
 

Mork

Mitglied
Sehr gut, dank dir :) Also geht dann der Pfeil von ProductRepository zu Product. Genau, ich will nur aussagen, dass der eine den anderen benutzt. Verwendet man DAO und Repository sononym oder unterscheiden sich die Pattern grundlegend?
 
M

maki

Gast
Also geht dann der Pfeil von ProductRepository zu Product
Würde mal jaein sagen :)
Das Repository "liefert" Product(s), aber interessanter ist doch, wer das Repository nutzt, oder nicht?

DAOs sind Teil der Persistenzschicht, während Repositories Teil der Domäne sind ;) Das ist imho der einzige Unterschied.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
1 Modellierung eines Bankkunden Java Basics - Anfänger-Themen 6
N Modellierung eines Programms in UML (Klassendiagramm) Java Basics - Anfänger-Themen 2
I Arbeitszeit / Zeiterfassung - Gedanken und Modellierung Java Basics - Anfänger-Themen 122
L Modellierung Widerstandsnetzwerk Java Basics - Anfänger-Themen 15
M Problem in der Modellierung Java Basics - Anfänger-Themen 20
N Modellierung, vererbung, Java Basics - Anfänger-Themen 163
D Verständnisfrage zur Modellierung einer HDD Java Basics - Anfänger-Themen 17
F OO - Modellierung Java Basics - Anfänger-Themen 24
S Modellierung von Karteneffekten ähnlich YUGIOH Java Basics - Anfänger-Themen 2
B Klassen Modellierung einer Kneipe Java Basics - Anfänger-Themen 86
A Modellierung Java Basics - Anfänger-Themen 8
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
laxla123 Eigenschaften eines Algorithmus (determiniert vs.. deterministisch) Java Basics - Anfänger-Themen 2
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Fehler Semikolon fehlt - ich weiss aber nicht wo da noch eines hin sollte... Java Basics - Anfänger-Themen 21
J Farbe des Striches eines TitledBorders ändern Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
walid Öffnungszeiten eines Geschäftes Java Basics - Anfänger-Themen 3
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
U Eigenschaft eines JTextfiels per ActionListener ändern... Java Basics - Anfänger-Themen 2
B Synchronisation eines kleinen Museums Java Basics - Anfänger-Themen 47
krgewb Breite und Höhe eines Bildes in base64 auslesen Java Basics - Anfänger-Themen 3
Sachinbhatt Was ist die Notwendigkeit eines Sammlungsframeworks in Java? Java Basics - Anfänger-Themen 2
N Textdatei aus Resourcen-Ordner eines Projekts/ jar-file lesen Java Basics - Anfänger-Themen 4
B Produkt eines double - streams Java Basics - Anfänger-Themen 3
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
S Variablen Letzte Zeile eines Strings entfernen Java Basics - Anfänger-Themen 1
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
J Größe eines Strings in Pixel Java Basics - Anfänger-Themen 18
M Parse-Tree eines statements darstellen Java Basics - Anfänger-Themen 0
H Java verkettete Liste, Wert eines Index zurückgeben Java Basics - Anfänger-Themen 1
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Hinzufügen eines Objektes in ein Objekt-Array Java Basics - Anfänger-Themen 62
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
A Rekursive Implementation eines Codes Java Basics - Anfänger-Themen 4
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
M Konstruktor ohne Übergabe eines Wertes Java Basics - Anfänger-Themen 7
M Wie kann ich in einem Konstruktor die Methode eines anderen Interfaces mit den jeweiligen Parametern aufrufen? Java Basics - Anfänger-Themen 8
M Wie erreiche ich das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 2
M Wie erreiche ich es das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 0
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
A Optimierung eines Programms: Mergen der Dateien Java Basics - Anfänger-Themen 23
melisax Alle Möglichkeiten eines Wortes angeben Java Basics - Anfänger-Themen 3
A Java, verarbeitung eines xml-files Java Basics - Anfänger-Themen 2
C Fehler beim erstellen eines Objektes Java Basics - Anfänger-Themen 3
B Konkatenieren eines Strings und inkremtierenden Zahl zu einer INT Variablen Java Basics - Anfänger-Themen 7
F Initialisieren eines Web-Mp3 Players in Tabs durch "booleans" erst wenn Tab geöffnet wird ...? Java Basics - Anfänger-Themen 1
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
C Überprüfen eines Programms auf Syntaxfehler Java Basics - Anfänger-Themen 3
S Wie kann ich den Bereich eines Integers begrenzen? Java Basics - Anfänger-Themen 2
nonickatall Grundsätzliches Verständnisproblem des Aufbaus eines Programms Java Basics - Anfänger-Themen 19
B Downgrade eines bestehenden Projektes Java Basics - Anfänger-Themen 5
amelie123456 Geschwindigkeit der Methode bewegeDich eines Objekts ändern Java Basics - Anfänger-Themen 2
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J maximaler Wert eines Integers Java Basics - Anfänger-Themen 14
TimoN11 IntelliJ , Ausgabe von einem Quellcode in Eingabe eines Quellcodes Java Basics - Anfänger-Themen 1
Z Rückgabe eines Values in umgekehrte richtung Java Basics - Anfänger-Themen 5
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
B fragen zu Aufbau eines UML-Klassendiagramm Java Basics - Anfänger-Themen 1
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
M Benutzereingabe eines Codes verbessern Java Basics - Anfänger-Themen 3
B Modulo-Operator anhand eines Beispieles erklären Java Basics - Anfänger-Themen 7
J Verschieben von Buchstaben in einem String um vorgegebene Anzahl von Zeichen innerhalb eines weiteren String Java Basics - Anfänger-Themen 12
F Auf Variablen eines Konstruktors zugreifen Java Basics - Anfänger-Themen 4
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
marcooooo Separator zwischen allen Zeichen eines Strings einfügen Java Basics - Anfänger-Themen 29
C Wie kann ich Versionen eines Projektes in Eclipse erstellen? Java Basics - Anfänger-Themen 3
yoskaem Text Color durch Klicken eines Buttons in anderer Activity ändern Java Basics - Anfänger-Themen 2
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
R Löschen und ausgeben eines Teilbaums Java Basics - Anfänger-Themen 3
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
M Hilfe bei Strukturierung eines Buchungssystems Java Basics - Anfänger-Themen 3
M Erstellen eines insets Objekts, GridBagLayout Java Basics - Anfänger-Themen 13
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
W Random Zahl unter Berücksichtung eines Durchschnitts Java Basics - Anfänger-Themen 7
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
C Erstellen eines Widerstandsnetzwerks Java Basics - Anfänger-Themen 10
C Methode Seiten tauschen eines erstellten Rechtecks mit Seite A und B Java Basics - Anfänger-Themen 9
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
J Problem bei der Programmierung eines Tannenbaums Java Basics - Anfänger-Themen 9
F Berechnung der Rektaszension und Deklination eines Sterns Java Basics - Anfänger-Themen 7
1 Erste Schritte Was denkt ihr über eines meiner ersten Javaprogramme? Java Basics - Anfänger-Themen 2
A Problem bei returnen eines Wertes Java Basics - Anfänger-Themen 6
D Input/Output Problem bei der Benutzereingabe eines Befehls Java Basics - Anfänger-Themen 14
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9
M Hinzufügen eines Objekts auf ein Map Java Basics - Anfänger-Themen 4
M Auf einen Array innerhalb eines Objekts zugreifen Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben