Klassen Doppelte werte Filtern XML, Datenbank und DOM

BarBQ

Mitglied
Hi Leute ich habe folgendes Problem.

Ich habe hier eine XML Datei mit mit Daten von Authoren und Büchern, genau genommen sind es knapp 420 Datensätze. Also sie sind immer ein Übergeordneten Tag zugeordnet.

Ich habe 2 Klassen erstellt eine baut eine Verbindung zur Datenbank auf und übergibt die Parameter an die Datenbank. Und die 2. Klasse Parst die XML-Datei mit DOM und sucht die entsprechenden Parameter raus. :rtfm:

Jetzt habe ich folgendes Problem es sind Zwar 420 verschiedene Bücher, aber auf 7 Bücher kommt im Durchschnitt 1 Author, wenn ich das ganze jetzt in die Datenbank schiebe nimmt er jede Author-Daten egal ob Doppelt oder Dreichfach oder nochmehr, einfach mit in die Datenbank.

Wie kann ich das Im grunde verhindern???
die Buchtitel gibt es nur einmal und haben eine ID

ich hatte mir gedacht schon zu filtern beim prepareStatement aufbau
so ungefähr:

Java:
		public static PreparedStatement getAuthor() throws Exception{
			try{
				if(conn == null){}
				if(data1 == null){
				   data1 = conn.prepareStatement(("INSERT INTO authors(_id, name, lowerCaseName, familyName)SELECT ?,?,?,? WHERE NOT EXISTS(SELECT name FROM authors WHERE _id = '?')"));
				} 
			}catch (Exception e){System.err.println("Fehler in der Authoren Klasse - " + e.getMessage());}
			return data1;
		}

kennt vllt einer von euch eine Lösung, ihr seit meine ltzte Hoffnung.

Vielen dank
Gruß
BarBQ :bahnhof:
 

Natac

Bekanntes Mitglied
Du kannst es natürlich auch über einen Filter machen.

Ich würde mir eine Map<String, Integer> anlegen, die den Autor-Namen auf seine ID mappt, die er in der Datenbank hat. Also in etwas folgendes (Pseudo-Code):
Java:
private Map<String, Integer> autorCache = new HashMap<>();

public Integer saveAutor(DomObj autor){
  Integer autorId = autorCache.get(autor.getName()); // Per name nach der ID gucken
  
  if(autorId == null){// Wenn id null -> Neuer Autor. Anlegen + ID merken
    autorId = getDatabase().save(autor); // Autor speichern und Id merken
    autoCache.put(autor.getName, autorId ); // Id unter dem Namen ablegen
  }

  return autorId; // Id zurückgeben, um sie bei saveBook(..) als FK nutzen zu können
}

Das halte ich für sehr viel einfacher, als sich ein kompliziertes SQL-Query auszudenken.
 
Zuletzt bearbeitet:

BarBQ

Mitglied
:rtfm:

erstmal Danke für die schnelle Antwort, aber ich hab da noch eine Frage
sieht er sich dann den Namen theoretisch nur 1 mal? auch bei der ersten befüllung???
 

BarBQ

Mitglied
Bzw. weiß ich nicht wie du das meinst :oops:

ich hab ja eine Automatisch generierten Schlüssel, also ID
wenn jetzt die XML so aufgebaut ist:

[XML]
<entry id="1">
<title>Buchtitel1</title>
<authors>
<author>Williamson</author>
</authors>
.
.
.
</entry>
[/XML]

und sagen wir, die folgenden <entry> sehen so aus:

[XML]
<entry id="2">
<title>Buchtitel2</title>
<authors>
<author>Williamson</author>
</authors>
.
.
.
</entry>
<entry id="3">
<title>Buchtitel3</title>
<authors>
<author>Williamson</author>
</authors>
.
.
.
</entry>
<entry id="4">
<title>Buchtitel4</title>
<authors>
<author>Williamson</author>
</authors>
.
.
.
</entry>
.
.
.
[/XML]

also mit dem Selben Autor. Die ID wird in der Datenbak generiert

kann ich da nicht irgendwo sagen
Wenn der erste <entry> mit Name Williamson kommt dann z.B. generire Automatisch die ID = 1 und merke sie dir
Wenn zweite <entry> kommt prüfe den Namen und wenn er da ist ignoriere den Tag authors und geh zum nächsten Tag.
und so weiter


:bahnhof::bahnhof::bahnhof::bahnhof::bahnhof:
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
J Variablen Doppelte Werte in Int Array Java Basics - Anfänger-Themen 10
S ArrayList Gruppieren, "Doppelte Werte" Addieren Java Basics - Anfänger-Themen 5
B Doppelte Werte aus Array entfernen ohne Import - Algorithmus Java Basics - Anfänger-Themen 5
S Array befüllen & auf doppelte werte prüfen Java Basics - Anfänger-Themen 6
P doppelte Werte im Array ausgeben. Java Basics - Anfänger-Themen 4
G Doppelte (Paar) Werte in einem Vektor finden Java Basics - Anfänger-Themen 6
K Warum werden immer noch doppelte Zahlen ausgegeben ? Java Basics - Anfänger-Themen 13
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
D Doppelte For Schleife / Array Java Basics - Anfänger-Themen 3
C das Doppelte des Wertes in der Console ausgeben Java Basics - Anfänger-Themen 10
tom.j85 Doppelte Foreach Schleife: Am Ende wird immer das Gleiche Objekt eingefügt Java Basics - Anfänger-Themen 4
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
N Best Practice Doppelte und einfach Anführungsstriche in Runtime.getruntime().exec() Java Basics - Anfänger-Themen 6
J Doppelte Ausgabe erzeugen Iterator Java Basics - Anfänger-Themen 6
L Doppelte Schleife Anpassen Java Basics - Anfänger-Themen 5
W Map doppelte Values löschen Java Basics - Anfänger-Themen 3
S CSV auf doppelte Einträge überprüfen Java Basics - Anfänger-Themen 8
S Doppelte Liste Einfügen Java Basics - Anfänger-Themen 1
M Argument in Integer verwandeln und das Doppelte davon printen Java Basics - Anfänger-Themen 9
T Klassen Doppelte Elemente aus Container entfernen Java Basics - Anfänger-Themen 6
M Erste Schritte Doppelte Ausgabe? (JList) Java Basics - Anfänger-Themen 1
kilopack15 Array auf doppelte Elemente überprüfen Java Basics - Anfänger-Themen 16
S Input/Output Doppelte Input-Abfrage Java Basics - Anfänger-Themen 3
K Input/Output Doppelte Ausgabe Java Basics - Anfänger-Themen 5
S Erste Schritte Doppelte Ausführung? Java Basics - Anfänger-Themen 4
E Threads Doppelte Threads beenden Java Basics - Anfänger-Themen 4
D Java doppelte Zahlen auch über 10 in einem String entfernen Java Basics - Anfänger-Themen 2
D Java doppelte Zahl/Zeichen in einem String entfernen Java Basics - Anfänger-Themen 6
O Doppelte For-Scheife Java Basics - Anfänger-Themen 6
E Array doppelte Einträge Java Basics - Anfänger-Themen 2
S Variablen Array in ArrayList auf doppelte Einträge überprüfen Java Basics - Anfänger-Themen 4
M Einfache und Doppelte Operatoren Java Basics - Anfänger-Themen 3
P Doppelte Datensätze aus CSV-Datei löschen Java Basics - Anfänger-Themen 17
P Doppelte Einträge in eine List Java Basics - Anfänger-Themen 5
R Doppelte löschen Java Basics - Anfänger-Themen 6
C Doppelte Einträge aus String [] Array entfernen. Java Basics - Anfänger-Themen 5
K Doppelte namen bei random Java Basics - Anfänger-Themen 3
U Doppelte Interfcae Implementierung Java Basics - Anfänger-Themen 10
M doppelte Einträge Emailempfänger... Java Basics - Anfänger-Themen 35
G txt-File als DB>doppelte Einträge verhindern/Suche/... Java Basics - Anfänger-Themen 10
DerGroßeNargus Doppelte Liste initialisieren Java Basics - Anfänger-Themen 2
H Datentypen Doppelte Verkette Liste - Verständnissproblem Java Basics - Anfänger-Themen 5
T Doppelte Liste Java Basics - Anfänger-Themen 8
R Schleife Doppelte Daten löschen Java Basics - Anfänger-Themen 3
V Doppelte Zahl suchen Java Basics - Anfänger-Themen 14
L Hilfe, doppelte Zufallszahlen Java Basics - Anfänger-Themen 13
G List suchen und doppelte rausfiltern Java Basics - Anfänger-Themen 3
T Doppelte Anführungszeichen ersetzen?? Java Basics - Anfänger-Themen 4
Luk10 Doppelte for-schleife Java Basics - Anfänger-Themen 7
P Doppelte Einträge in mehreren Textfiles finden und ausgeben Java Basics - Anfänger-Themen 8
T Array: Doppelte Charakteren löschen - Ein Lösungsversuch Java Basics - Anfänger-Themen 37
J doppelte Einträge in einem Array Java Basics - Anfänger-Themen 7
M Aufgabe: Array auf doppelte Zahl prüfen Java Basics - Anfänger-Themen 8
-horn- Doppelte Einträge entfernen, aus Array, List oder sonstwas Java Basics - Anfänger-Themen 9
G _NUR_ doppelte Einträge in einem Array behalten Java Basics - Anfänger-Themen 3
J Doppelte Integer aus einem Array entfernen - seltsames Prob. Java Basics - Anfänger-Themen 5
G doppelte Einträge im String Array löschen Java Basics - Anfänger-Themen 21
C Doppelte Punktnotation Java Basics - Anfänger-Themen 2
0 ArrayList - doppelte Einträge entfernen? Java Basics - Anfänger-Themen 9
S Methode, um doppelte Einträge in Array zu finden Java Basics - Anfänger-Themen 5
F doppelte Elemente in HashSet Java Basics - Anfänger-Themen 5
G java.util.LinkedList: Doppelte Elemente vermeiden Java Basics - Anfänger-Themen 5
G Wie doppelte Einträge in ComboBox vermeiden ? Java Basics - Anfänger-Themen 9
M Doppelte Einträge in einer datei löschen(nach timestamp)! Java Basics - Anfänger-Themen 4
D Doppelte Einträge einer Liste löschen Java Basics - Anfänger-Themen 6
B 2 ELists vergleichen und doppelte Einträge löschen Java Basics - Anfänger-Themen 11
S "doppelte" if-Anweisung Java Basics - Anfänger-Themen 10
F Doppelte Datensätze zusammenziehen Java Basics - Anfänger-Themen 2
V Doppelte Zahlen bei Lotto verhindern Java Basics - Anfänger-Themen 11
DrahtEck Methoden Methoden und Werte Java Basics - Anfänger-Themen 5
M Variablen Werte nach setzen, bei Abfrage wieder alter Wert Java Basics - Anfänger-Themen 10
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
F 2x 16bit Werte zu einem 32bit und dann splitten mit 0xb Java Basics - Anfänger-Themen 1
ptcho Werte/Position nach dem Funktionsaufruf tauschen? Java Basics - Anfänger-Themen 1
K Warum sind Werte in den Feldern ? Java Basics - Anfänger-Themen 2
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
N Einzelne Werte aus einem TreeSet auslesen Java Basics - Anfänger-Themen 2
TeacherMrSSimon Schachspiel, Werte in Figur eintragen klappt nicht Java Basics - Anfänger-Themen 23
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
M Werte in Felder speichern und geordnet ausgeben Java Basics - Anfänger-Themen 8
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
docmas 2DArray Werte werden nur untereinander ausgegeben Java Basics - Anfänger-Themen 1
M Nur int-Werte erlauben Java Basics - Anfänger-Themen 11
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode eine andere Methode um Werte wie z.B. 1 erhöhen? Java Basics - Anfänger-Themen 6
Igig1 Wie lasse ich dir Werte in einem Array zusammenrücken? Java Basics - Anfänger-Themen 4
Igig1 Welche Werte sind als default Werte in einem Array, der als Datentyp eine Klasse hat? Java Basics - Anfänger-Themen 1
J Methoden Positive Werte zählen Java Basics - Anfänger-Themen 3
E Meine JCombobox werte an ohne selectiert zu haben Java Basics - Anfänger-Themen 6
H OOP Werte mit Set verändern Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben