Komplexe Datenauswertungen in Java oder besser auf Datenbankseite ausführen?

Maik.Neumann

Aktives Mitglied
Hallo !

Ich habe mal eher eine theoretische Frage an euch. Man sagt ja, dass man mit dem Einsatz von JPA die Datenbankebene abstrahieren und dadurch eine Datenbank als Backend komplett austauschen könnte (z.B. eine Oracle DB gegen einen MS SQL Server DB usw.), ohne das dadurch die Funktionalität meiner Anwendung gefährdet wäre. Ob das nun wirklich Sinn macht, sein mal dahingestellt.

Nun kann ich mit Oracle sogenanntes PL/SQL programmieren und dadurch bereits serverseitig über mehrere Tabellen Daten über komplexe Abfragekonstrukte schnell zusammensuchen und diese dann an die Geschäftslogik meiner Anwendung weiterreichen. Eine Oracle Datenbank bietet hier ja sehr sehr viele Möglichkeiten, die eben herstellerspezifisch sind und die der MS SQL Server im Gegenzug (wenn überhaupt) gar nicht oder völlig anders implementiert hat.

Selbst wenn ich hier mittels JPA Entitys die Datenbankzugriffe abstrahiere, so wäre hier doch ein schnelles Austauschen des Backends schon nicht mehr- oder nur mit Mehrausfwand machbar.

Jetzt könnte man ja argumentieren, dass man genau aus diesem Grund die datenbankspezifischen Implementieren gar nicht nutzen sollte, sondern die Datenbank nur aus Datencontainer ansieht. Nach meinem Verständnis würde man durch die JPA Entitys die Daten "hochgeben" und dann dort die Datenaufbereitungen machen oder? Aber ist das wirklich effizient? Mit der Datenbank wäre man doch hier bestimmt schneller?

Aber sehe ich es richtig, dass wenn man hier so vorgeht, man viele sinnvolle Features einer Datenbank gar nicht nutzt und auch möglichst nciht nutzen will? Also bloß keine Geschäftslogik datenbankseitig plazieren?

Danke und Gruß
Maik
 

Thallius

Top Contributor
Der Punkt ist, dass auf Grund der großen Speicher heute die meisten "ottonormal" Datenbanken komplett ins RAM passen und von daher die ganze DB Performance gar nicht benötigt wird. Erst bei wirklich großen Datenmengen jenseits der Millionen oder entsprechend großen datensätzen, wird es dann auf einmal ganz plötzlich sehr langsam wenn man die DB umwandert. Blöd ist es dann wenn eine DB über die Jahre wächst und irgendwann diese Größe erreicht...

Gruß

Claus
 

Maik.Neumann

Aktives Mitglied
Der Punkt ist, dass auf Grund der großen Speicher heute die meisten "ottonormal" Datenbanken komplett ins RAM passen und von daher die ganze DB Performance gar nicht benötigt wird. Erst bei wirklich großen Datenmengen jenseits der Millionen oder entsprechend großen datensätzen, wird es dann auf einmal ganz plötzlich sehr langsam wenn man die DB umwandert.

Hallo !

Ich versteh nicht ganz, was Du hier in diesem Zuammenhang mit umwandern meinst? Wie soll denn eine gesamte DB in den RAM passen? Redest du hier von in memory Datenbanken?
 

Thallius

Top Contributor
Hallo !

Ich versteh nicht ganz, was Du hier in diesem Zuammenhang mit umwandern meinst? Wie soll denn eine gesamte DB in den RAM passen? Redest du hier von in memory Datenbanken?

Alle modernen DB's sind dermassen opötimiert, dass sie große RAM Caches haben mit denen sie arbeiten. Bei DB mit nur 10000 oder 100000 Datensätzern passen diese dann eben komplett in den Cache und somit ist es extrem schnell egal wie umständlich man abfragt. Und ja das ist dann quasi wie einen Memory DB.

Gruß

Claus
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F Komplexe Zahlen auf verschiedene Weise addieren Java Basics - Anfänger-Themen 18
C Komplexe For-Schleife Arrays Java Basics - Anfänger-Themen 6
D komplexe Datenstrukturen "klonen" Java Basics - Anfänger-Themen 4
O Komplexe Zahlen Java Basics - Anfänger-Themen 9
O Komplexe Zahlen Java Basics - Anfänger-Themen 10
D Welche API für komplexe XML-Struktur? Java Basics - Anfänger-Themen 25
G Methoden um Komplexe Zahlen zu berechnen? Java Basics - Anfänger-Themen 4
G Komplexe Algorithmen implementieren Java Basics - Anfänger-Themen 4
Zed Komplexe for -Schleife Java Basics - Anfänger-Themen 4
W Komplexe Zahlen und großes Problem Java Basics - Anfänger-Themen 21
T komplexe Strukturen in Servlet-Context speichern möglich? Java Basics - Anfänger-Themen 5
S Switch für komplexe Datentypen? Java Basics - Anfänger-Themen 7
G Komplexe Datenstruktur (Liste heterogener Datensätze) ? Java Basics - Anfänger-Themen 2
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15

Ähnliche Java Themen

Neue Themen


Oben