Frage zum Entwurf / json-Datenmodell

JanHH

Top Contributor
Hallo,

mal wieder ein Posting von mir nach einiger Abwesenheit..

habe eine Software (JEE6/Webanwendung/postgresql), bei der ein reichlich komplexes Datenmodell als json-String gespeichert wird. Das Datenmodell besteht aus einer Verschachtelung von Objekten einer Reihe von Klassen.

Ich frage mich nun, was besser ist:

a) ein "dummes Modell", welches nur aus "leeren Klassen", die nur properties sowie getter und setter enthalten, besteht, und zusätzlich eine "action"-Klasse(/-Objekt), welches die Funktionen bereitstellt, die notwendig sind, um mit dem Datenmodell zu arbeiten

b) ein "intelligentes Modell", bei dem die Objekte neben den Properties auch selber die notwendigen Methoden beinhalten

a ist eher ein prozeduraler Entwurf, b eher "klassisch objektorientiert", aber bei a wird Modell und Funktion sauberer getrennt (was ja bei Webanwendungen durchaus auch ein Aspekt ist).

Ich bin unentschlossen. Was ist heutzutage der bessere Ansatz?
 

Tobse

Top Contributor
Ich verstehe noch nicht so ganz, worauf du raus willst. Im allgemeinen oder wenn es speziell drum geht, mit JSON zu arbeiten?

Rein prinzipiell spreche ich mich als überzeugter DDD Entwickler für b) aus. Das jetzt ausführlicher zu begründen macht aber wenig Sinn, ohne zu wisse, worauf deine Frage abzielt.
 

JanHH

Top Contributor
Hmm.. ich hab, als ich mich in die JEE-Materie eingearbeitet hab, speziell was JPA/Hibernate angeht, gelernt (von einem Freund der da sehr fit drin ist und mir das erklärt hat), dass die model/entity-Klassen "dumm" sein sollen und keine Funktion kapseln, ausserdem dass man da eine allzu fein granulierte Klassenhierarchie unterlässt (weil das die Datenbankstruktur sehr kompliziert machen würde) sondern eher flache, designtechisch nicht unbedingt immer perfekt dem theoretischen Ideal entsprechende Klassenhierarchien baut.

Nun hab ich hier allerdings keine JPA-Entities, sondern ein json-Objekt, insofern ist das sicher nicht 1:1 übertragbar, allerdings ist die Klassenhierarchie auch hier eher simpel gestrickt, um das json-konvertieren nicht unnötig komplex zu gestalten, und die Klassen sind "dumm". Also letztlich dasselbe.

Gibt es gute Gründe, das so beizubehalten, oder ist das im Grunde egal, es hat keinen architektonischen Nachteil, derartige model-Klassen "sauber objektorientiert intelligent" zu gesatlten? Das ist im Grunde die Frage, um die es mir geht. Gibt es irgendeinen guten Grund (ausser anfänglicher faulheit) für diesen Entwurf (Variante a).
 

Tobse

Top Contributor
Solange du von und nach JSON persistierst kannst du von den "intelligenten" Objekten nur profitieren. Die Argumente dei bei einem O/RM gegen eine sehr Komplexes Modell sprechen, treffen auf JSON (oder aug Graph-Datenbanken) nicht zu.
 

JanHH

Top Contributor
Hm.. in der Tat gibt es (theoretisch, irgendwann mal) die Überlegung, das json-Modell doch in einzelne Entity-Objekte aufzubrechen und alles fein granuliert in die Datenbank zu tun - und zwar, um den z.Zt. stateful in einen stateless-Entwurf umzubauen, zwecks load balancing/clustering. Wäre damit ja viel einfacher. Aber ob es je dazu kommen wird.. eher fraglich. Momentan müsste bei einem stateless Entwurf bei jedem Seitenaufruf der gesamte json-String geladen und in Objekte konvertiert werden, was mir wie sehr sehr viel overhead und ressourcenfressend vorkommt. Aber dieser prozedurale Ansatz ist schon irgendwie eher doof.
 

Tobse

Top Contributor
bei einem stateless Entwurf bei jedem Seitenaufruf der gesamte json-String geladen und in Objekte konvertiert werden, was mir wie sehr sehr viel overhead und ressourcenfressend vorkommt. Aber dieser prozedurale Ansatz ist schon irgendwie eher doof.

Zum einen: das muss nicht sein; im Java EE bereich können sich mehrere Requests den selben Heap und damit auch die selben Domain-Objekte teilen.
Zum anderen: wenn du mit einer Datenbank arbeitest, ist es ganz genau das selbe: Daten, die nicht da sind, müssen aus der DB geladen und in Objekte umgewandelt werden.

Dazu kommt: der Aufwand bei Verwendung einer Datenbank ist merkbar höher als beim JSON. Aber er ist so gerin, dass so ziemlich alle Web-Anwendungen (dieses Forum mit eingeschlossen) diesen "overhead" akzeptieren.
Durch optimierte Abfragen kann man da auch viel an Performance rausholen.
 

JanHH

Top Contributor
Hm, stimmt. Ausserdem ist das besagte Datenmodell mehr so eine "Schablone", aber speichert keine session-spezifischen Daten (die landen dann in der Tat in entities in der Datenbank). man müsste das ganze Ding also nur einmal instanziieren, und alle requests könnten sich das teilen. hm.
 

dayaftereh

Top Contributor
Wie sieht es mit einer NonSQL Datenbank aus, in der du deine Json-Objekt ablegen kannst und zusätzlich mit Hilfe der Datenbank suchen bzw filtern Kannst ?
 

JanHH

Top Contributor
hm, das sagt mir erstmal gar nix, aber scheint mir nicht notwendig. das funktioniert alles gut so wies ist. das json objekt wird halt einfach als string gespeichert.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
H2SO3- SCJP Chapter 3 Frage 10. Falsche Antwort? Allgemeine Java-Themen 15
H Frage sinnvolle Datenspeicherung und -verarbeitung Allgemeine Java-Themen 3
EnHancEd[] kurze enum-Frage Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben