2 Arrays mit komplexen Datentyp vergleichen

MarkusM

Aktives Mitglied
Hallo zusammen!

Ich bin noch ein Neuling in Sachen Javaprogrammierung und brauche mal einen grundsätzlichen Rat wie ich bei einer Problemstellung am besten vorgehe.

Problem:
Ich habe in einer Datenbank zwei vom Aufbau her identische Tabellen, welche mit Datensätzen gefüllt sind. Der Primärschlüssel setzt sich hierbei aus mehreren Feldern zusammen. Nun möchte ich die Datensätze der Tabellen anhand des Primärschlüssels matchen und dann den Inhalt der weiteren Zellen auf Abweichungen untersuchen (Kurz: Primärschlüssel muss logischerweise gleich sein, der Inhalt der weiteren Datenzellen - ca. 100 - soll auf Abweichungen geprüft werden.)

Lösungsansatz a):
Erstellen eines Views, der den Abgleich vornimmt => Arbeit von der Datenbank machen lassen.

Lösungsansatz b):
Einlesen der Tabellendaten in zwei Arrays mit einem komplexen Datentypen, welcher die Tabellenstruktur widerspiegelt. Dann ein Vergleich der beiden Arrays über den Primärschlüssel und abgleich der einzelnen Elemente. => Arbeit wird von Java aus im Speicher erledigt.

Ich hoffe, die Fragestellung kommt einigermaßen verständlich rüber :(
Mir ist schon klar, dass hier keine komplette Lösung als antwort kommen kann, es geht mir vielmehr um mögliche Lösungsansätze und wie die erfahrenen Hasen das lösen würden. Für den Ansatz B, der mich unabhängiger von der "Art" der Datenbank macht, habe ich keine Umsetzungsidee - vermute aber mal, dass das eher komplexer wird.

Aufgebaut habe ich das Ganze bisher ohne ein Framework wie Hibernate, da ich zunächst mit dem Grundprinzip klarkommen möchte und zwei Tabellen eigentlich nicht wirklich komplex sind...

Bin für alle Ideen, Anregungen und Vorschläge dankbar!

Viele Grüße

Markus
 

nrg

Top Contributor
Wie performant soll das Ganze sein? eine Option wäre vllt eine Klasse zu schreiben, die einen Datensatz wiederspiegelt und dort die equals mit der Primärkeylogik überschreiben. Dann die Tabellen in Collections vom Typ dieser Klasse einlesen. Nun kannste das mit contains o.ä. matchen. Das ist aber mit Sicherheit nicht die schnellste Variante.
edit: anders würde ich das - wie du schon selbst gesagt hast - erst mal via SQL joinen. danach kannste ja immernoch auf ne view o.ä. gehen. das ist halt auf jedenfall schneller als das Mapping selbst zu machen..
 
Zuletzt bearbeitet:

MarkusM

Aktives Mitglied
Tja, wie performat soll das Ganze sein... Gute Frage.... Aufgrund der mangelnden Erfahrung habe ich null Idee was in der Praxis schneller ist. :oops: Die Anzahl der Datensätze je Tabelle schwank auch zwischen 10 - und 200.000, was die Sache mit der Javalösung sicher noch langsamer macht, oder?

Einfacher ist wahrscheinlich die Datenbankvariante mit dem View. Aufgrund meiner Kenntnisse tendiere ich auch eher in diese Richtung.
 

nrg

Top Contributor
in java würde man das imho auch nicht selbst mappen. das sollte vorher schon das DMS machen. Was heisst "auf Abweichungen überprüfen"? Das kannst du dann natürlich schon mit Java machen bzw. da kommt dann sql auch irgendwann an seine Grenzen (kommt eben darauf an, wie "tief" dir Prüfung sein soll).
 

MarkusM

Aktives Mitglied
Ich mach mal ein Beispiel was ich mit "auf Abweichungen prüfen" meine.

Felder in Tabelle1:

ID1: 1 (Primärschlüssel)
ID2: A (Primärschlüssel)
Saldo: 10,50
Name: Müller, Fritz
... (ca. 100 weitere Felder)

Felder in Tabelle2:
ID1: 1 (Primärschlüssel)
ID2: A (Primärschlüssel)
Saldo: 10,00
Name: Müller, Ferdinand
... (ca. 100 weitere Felder)

Nun möchte ich die beiden Datensätze durch den Primärschlüssel "matchen" und danach die einzelnen Felder inhaltlich auf Übereinstimmung abgleichen. In dem Beispiel würden als 2 Abweichungen auftreten Saldo 10,50<>10,00 (Ausweis: Differenz) und Name Müller, Fritz <> Müller, Ferdinand (Ausweis: false). Natürlich gibt es auch Datensätze die stimmig sind und wahrscheinlich auch welche die nur in Tabelle1 oder in Tabelle2 enthalten sind.

Aber je mehr ich darüber nachdenke, desto eher kommen wohl die Views in Frage.

Wie schaut es eigentlich performancemäßig aus, wenn ich die Daten mit einem SQL-Statement in ein Java RecordSet schaufle und dort den Abgleich durchführe? Gibt das Probleme bei > 100.000 Datensätzen auf nem normalen Desktoprechner? So könnte ich mir theoretisch das Ablegen des Views sparen, oder?
 

nrg

Top Contributor
das meinte ich mit "das sollte vorher schon das DMS machen".

Du musst nicht unbedingt eine View anlegen. Du kannst die Tabellen via SQL joinen und in ein RecordSet laden. Dann kannste das ganz einfach miteinander vergleichen und das würde auch sehr flott gehen. Beide Tabellen einzeln laden und selbst mappen geht schon auch (s. oben) aber wird wesentlich langsamer sein und auch nicht unbedingt im Sinne des Erfinders...
 

MarkusM

Aktives Mitglied
Danke Dir für Deine Hilfestellungen. Ich werde mein Glück mal versuchen! Die Lösung mit dem SQL Join und das Ganze ins Recordset hört sich ganz gut an. :toll:
 

tagedieb

Top Contributor
Lösungsansatz b):
Einlesen der Tabellendaten in zwei Arrays mit einem komplexen Datentypen, welcher die Tabellenstruktur widerspiegelt. Dann ein Vergleich der beiden Arrays über den Primärschlüssel und abgleich der einzelnen Elemente. => Arbeit wird von Java aus im Speicher erledigt.

Das hab ich jetzt nicht ganz verstanden. Du hast 2 Tabellen mit identischen PrimaryKeys. Wieso willst du die Tabellen in ein Array laden? Du kannst doch Record fuer Record abarbeiten.

Wieso liest du nicht Tabelle 1 sequentiel durch. Pro Record kannst du dann den entsprechenden Record aus Tabelle 2 rauslesen und die beiden vergleichen!

Diese Loesung beruecksichtigt aber nicht Records, die nur in Tabelle 2 existieren (falls dies der Fall sein sollte).
 

MarkusM

Aktives Mitglied
Das war eigentlich mein Gedankengang. Ich bin mir halt nur unsicher, was performanter ist: die von Dir vorgeschlagene Lösung, oder anstelle des sequentiellen Auslesens und Matchens ein neues Recordset mit einem SQLJoin zu erzeugen...

Irgendwie glaube ich die Idee mit dem SQLJoin ist flotter bei >100.000 Datensätzen, oder?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
C Wie 2 Arrays zusammenfügen und sortieren? Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
K Sudoku mit 2D Arrays Java Basics - Anfänger-Themen 19
T Vertikales Histogramm mit Arrays Java Basics - Anfänger-Themen 3
JD_1998 Arrays einlesen, zwischenspeichern und wieder ausgeben Java Basics - Anfänger-Themen 8
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
mihe7 Von Datentypen und (mehrdimensionalen) Arrays Java Basics - Anfänger-Themen 4
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L If und else bei 2 Dimensionalen Arrays Java Basics - Anfänger-Themen 8
1 Arrays Java Basics - Anfänger-Themen 7
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
L Addition von Arrays über die Parameterliste Java Basics - Anfänger-Themen 11
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J 2D Arrays summieren Java Basics - Anfänger-Themen 21
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
A Java.util.Arrays Java Basics - Anfänger-Themen 15
T Methodenverknüpfung mit Arrays Java Basics - Anfänger-Themen 4
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
F Eine Zahl mit Arrays vergleichen Java Basics - Anfänger-Themen 7
A 2d Arrays aus txt.file einlesen Java Basics - Anfänger-Themen 16
B Arrays Java Basics - Anfänger-Themen 4
P Arrays "automatisch" erstellen lassen Java Basics - Anfänger-Themen 12
B Nur eine bestimmte Anzahl an Arrays ausgeben Java Basics - Anfänger-Themen 9
H Gemeinsame Schnittmenge zweier Arrays ausgeben Java Basics - Anfänger-Themen 12
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9
A Summe des Arrays pd mit alternativer Schleife Java Basics - Anfänger-Themen 2
S Elemente eines Arrays bei Ausgabe auslassen Java Basics - Anfänger-Themen 2
M Verständnisproblem der Rekursion bei Arrays Java Basics - Anfänger-Themen 8
F Mehrdimensionale Arrays Java Basics - Anfänger-Themen 12
M Arrays in Funktion Kopieren und Bearbeiten Java Basics - Anfänger-Themen 4
W Erste Schritte Arrays befüllen und ausgeben Java Basics - Anfänger-Themen 11

Ähnliche Java Themen

Neue Themen


Oben