Collections Datenbankdaten in einer Map speichern, bearbeiten, sortieren und wieder in Datenbank schreiben

Fleur de Soleil

Aktives Mitglied
Hallo zusammen,

ich habe folgendes Problem beim Überlegen eines Konzepts für mein Programm. Ich habe eine Oracle-Datenbank, aus der Daten gelesen werden sollen. Diese Daten sollen dann in eine Map gepackt werden, damit ich sie sortieren kann (gibt es eine andere Möglichkeit?).

1. Problem: Welche Map ist für Daten aus einer Datenbank am besten geeignet(Zugriff über Spaltennamen??)?

2. Problem: Kann man in die Map auch noch eine eigene Spalte einfügen die nicht aus der Datenbank kommt?

3. Problem: Wie kann ich meine geänderten Daten wieder in die Datenbank zurückschreiben, ohne dass meine eigene Spalte übernommen wird und die Daten, die ja anders sortiert sind, wieder in der richtigen Spalte in der DB landen?

Ich weiß sind drei nicht einfache Fragen, zumindest die letzte (meiner Meinung nach), aber
ich wäre sehr dankbar, wenn ihr Tipps oder Lösungen für mich hättet die mich nur irgendwie weiter bringen.

Mit freundlichen Grüßen

Fleur

P.S.: Frohe Weihnachten :applaus:
 

Fleur de Soleil

Aktives Mitglied
Hi ARadauer,

Danke für deine Antwort, aber

ORDER BY im select?
kommt nicht in Frage, da der Sort über die neue eigene Spalte, und eine Spalte aus der DB laufen soll. Beim SELECT ist die Spalte ja dann noch nicht verfügbar.

problem 3..
in dem die zeile eine eindeutige id hat und du diese im update verwendest..

Eindeutige ID hab ich durch das Schlüsselattribut aus der DB, aber wie läuft dann das Update ab?? Muss den UPDATE ja irgendwie über ein RowSet oder so machen.

Wie ich bereits im ersten Post geschrieben bin ich noch beim Konzept und Frage mich eben gerade welche Map am besten passt?? Code habe ich somit noch nichts. Außer eben die Connection zur Datenbank.

Hoffe ihr könnt mir noch weiterhelfen.

LG Fleur
 

timbeau

Gesperrter Benutzer
Kann man sich da nicht pro Datensatz einen geeignetes Javaobjekt basteln welches dann je einen Datensatz aus der DB darstellt?

Die Map sähe dann aus Map<String, DB-Objekt> oder statt String int oder sowas. Dann kann man nach der eigenen Spalte sortieren und schreibt später nur die DB-Objekte zurück. Ist es denn wichtig, wie die Objekte in der DB liegen? Eher nicht oder?
 

Fleur de Soleil

Aktives Mitglied
Hi,

ich glaube nicht, dass das Speichern der Datensätze in Objekten sinnvoll ist. Habe mehr als 36.000 Datensätze ;)

Was meinst du mit "wie sie ihn der DB liegen"? Meinst du den Datentyp??

LG Fleur
 

timbeau

Gesperrter Benutzer
Hmm, das weiß ich nicht. Ich hab hier ein Wiktionary mit 130.000 Datensätzen und das dauert mittels SQL 12sec zu laden mittels Hibernate und H2 ca 15sek und dann hab ich ebensoviele Objekte.

Ich meinte ob die Sortierung in der DB erhalten bleiben muss
 

Fleur de Soleil

Aktives Mitglied
Also die Sortierung ist nur relevant in der Map für das bearbeiten der Datensätze. Danach werden die Daten in der DB per Schlüsselattribut geupdatet.

Zu deinem Vorschlag mit den Objekten in der Map, wie kann ich innerhalb der Map nach Attributen der Objekte sortieren?
 

timbeau

Gesperrter Benutzer
Das Objekt muss Comparable implementieren. Die Methode die du dann überschreiben musst sieht dann ca so aus:

Java:
public int compareTo(Objekt o) {
	return this.Attribut VERGLEICH o.Attribut
	}

Und damit kannste das ganze später per Collection.sort sortieren lassen.

Ich denke aber das hier Aradauer auch noch was schreiben wird
 

Fleur de Soleil

Aktives Mitglied
Ich dachte das erstellen von mehreren Tausend Datensätzen als Objekt dauert ziemlich lange. Aber anscheinend ist das nicht so, wenn man eure Bedenken sieht.

Was eine Map ist meine ich zu wissen. Einem Bezeichner wird ein Value zugeteilt. Wenn ich damit richtig liege suche ich im Prinzip eine Map, bei dem ich dem Bezeichner mehrere Values zuteilen kann (=ArrayList??).

Werde mich aber mal mit den Datensätzen als Objekte auseinander setzen. Hab noch nicht ganz verstanden wie ich da die vergleiche anstellen soll sodass am Ende alle Datensätze sortiert sind. Muss ich dafür jedes Objekt mit jedem anderen vergleichen??
 

timbeau

Gesperrter Benutzer
Alles was comparator oder comparable implementiert kann von Java verglichen werden.

Wenn du ein Objekt Mensch hast mit Alter und Namen kannst du dir obige Methode so umschreiben, das Alter1-Alter2 returnt wird. Somit weißt du/Java wie sortiert werden soll.

Was du machen willst ist ne Map mit Maps mit Maps oder sowas :)


Vielleicht solltest du einfach mal bisschen Coden und 10 Datensätze einlesen und damit testen.
 

ARadauer

Top Contributor
Ich dachte das erstellen von mehreren Tausend Datensätzen als Objekt dauert ziemlich lange.

Java:
import java.util.ArrayList;
import java.util.Date;

public class Kunde {
   
   private String name;
   private int alter;   
   private String vorname;
   private String adresse;      
   private Date geburtsdatum;
   
   public static void main(String[] args) {
     long t = System.currentTimeMillis();
      ArrayList<Kunde> kunden = new ArrayList<Kunde>();      
      for(int i = 0; i <100000; i++){
         kunden.add(new Kunde(System.currentTimeMillis()+"", 3, System.currentTimeMillis()+"", System.currentTimeMillis()+"", new Date()));
      }     
      System.out.println("Anzahl: "+kunden.size()+" Dauer: "+(System.currentTimeMillis()-t)+" ms");      
   }

   public Kunde(String name, int alter, String vorname, String adresse, Date geburtsdatum) {
      super();
      this.name = name;
      this.alter = alter;
      this.vorname = vorname;
      this.adresse = adresse;
      this.geburtsdatum = geburtsdatum;
   }

   public String getName() {
      return name;
   }

   public void setName(String name) {
      this.name = name;
   }

   public int getAlter() {
      return alter;
   }

   public void setAlter(int alter) {
      this.alter = alter;
   }

   public String getVorname() {
      return vorname;
   }

   public void setVorname(String vorname) {
      this.vorname = vorname;
   }

   public String getAdresse() {
      return adresse;
   }

   public void setAdresse(String adresse) {
      this.adresse = adresse;
   }

   public Date getGeburtsdatum() {
      return geburtsdatum;
   }

   public void setGeburtsdatum(Date geburtsdatum) {
      this.geburtsdatum = geburtsdatum;
   }
}
Anzahl: 100000 Dauer: 485 ms find ich vertrettbar...
 

Fleur de Soleil

Aktives Mitglied
So ihr beiden, jetzt habe ich mal mit einem kleinen Test angefangen. Wie kann ich jetzt bei diesem kleinen Beispiel meine Keys und die Attribute meines Objekts pro Key ausgeben lassen?? Oder zum Beispiel alle Attribute nr. meiner Datensatz-Objekte um 10 erhöhen??


Java:
import java.util.Date;
import java.util.HashMap;


public class Test {

	public HashMap<Integer, Datensatz> alleDatensaetze;
	public Datensatz datensatz;

	public static void main(String[] args) {
		HashMap<Integer, Datensatz> alleDatensaetze = new HashMap<Integer, Datensatz>();

		for (int i = 0; i < 5; i++){
			Datensatz datensatz = new Datensatz((00 + i),"Test" + i, new Date());
			alleDatensaetze.put(i, datensatz);
		}
	}
}
Java:
import java.util.Date;


public class Datensatz {
	public int nr;
	public String name;
	public Date datum;

	public Datensatz(int nr, String name, Date datum){
		this.nr = nr;
		this.name = name;
		this.datum = datum;
	}
}


EDIT: Okay hab es selbst über Aufrufe von Methoden der Klasse Datensätze herausbekommen.

Meine Frage ist jetzt eher, wie bekomme ich die Daten aus der DB in die Objekte rein??
 
Zuletzt bearbeitet:

timbeau

Gesperrter Benutzer
Eine HashMap iteriert man zum Beispiel über das KeySet:

Java:
Set<Integer> set = alleDatensaetze.keySet();
        for (Integer integer : set) {
			System.out.println(integer + " : " + alleDatensaetze.get(integer).getNr() + alleDatensaetze.get(integer).getDatum());
		}

@DB: Hast du eine Connection und kannst Statements absetzen?
 
Zuletzt bearbeitet:

Fleur de Soleil

Aktives Mitglied
Hab ich noch nicht, aber das kann ich prinzipiell. Würde nur zuerst gerne wissen wie ich die Daten als Objekte bekomme. Das Ergebnis meines Statement ist dann zum Beispiel ein ResultSet oder ein RowSet. mit rs.next() kann ich ja dann durch das Set gehen, aber wie bekommen ich das hin, dass zum Beispiel die Daten aus der Spalte "Anrede" im Objekt als name gespeichert wird??
 

henpara

Bekanntes Mitglied
rowSet
Da steht eig. genau das was du brauchst (also wie du den Inhalt pro Zeile einzelner Spalten bekommst)

Im Prinzip, wenn du weißt wie der Daten aufbau ist, würd ich auch eine neue Klasse erstellen, zB class Dataset, welches comparable implementiert. Dann kannst du dir für jede Spalte attribute überlegen, zusätzliche attribute anlegen.

Beim result-set vom select gehst du für jede Zeile eben durch die Spalten und setzt die Attribute für die Objekte. Seblst bei einer Halben Millionen Objekten stellt das ganze noch kein Problem dar.

Mfg
 

timbeau

Gesperrter Benutzer
Du gehst jeden Datensatz durch und machst noch setter-Methoden in den Datensätzen ala
Java:
 public void setName(String anrede){
name = anrede;
}

edit:

Nochmal zum Sortieren.

Du musst bei ner Map entweder direkt nach den Keys sortieren, das geht wenn es primitive Datentypen sind einfach mittels Collections.sort() oder du imlementierst Comparable mit der comparTo Methode.
 
Zuletzt bearbeitet:

Fleur de Soleil

Aktives Mitglied
Ja am compareTo bin ich gerade dran. Aber was füge ich für VERGLEICH jetzt ein, damit er mir die Namen nach dem Alphabet sortiert?? Und wie rufe ich das dann in der HashMap alleDatensaetze auf??

Java:
public int compareTo(Datensatz o) {
		return this.name VERGLEICH o.name;
	}
}
 

timbeau

Gesperrter Benutzer
z.B. ein minuszeichen reicht bei numerischen Attributen.


Alle Datensätze erhälst du indem du diese aus der HashMap einliest und dann in einer Liste einfügst. sortierst. Bzw keys bekommst du direkt über keySet
 

Fleur de Soleil

Aktives Mitglied
Ich meinte mit meiner zweiten Frage wie ich das Sort in meiner HashMap die den Namen "alleDatensaetze" hat, ausführe. Nicht wie ich alle Datensätze bekomme.

Aber trotzdem Danke. Hab jetzt endlich Feierabend und auch noch Urlaub. Werde mich aber die Tage zu Hause auch nochmal damit beschäftigen und dann im neuen Jahr mit dem Programmieren anfangen.

Bis dahin LG Fleur.

Und Danke für eure wirklich extrem schnelle Hilfe
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
P Iterieren mit einer Foreach in Lambdaschreibweise und Counter. Java Basics - Anfänger-Themen 1
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
M Wie richte ich eine Diagonale an Robotern in einer World ein? Java Basics - Anfänger-Themen 15
YAZZ BlueJ Bewegung einer Figur im Kreis Java Basics - Anfänger-Themen 4
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
B GUI extension mit einer Liste verbinden Java Basics - Anfänger-Themen 1
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
J if-Schleife innerhalb einer if-Schleife wird in der Konsole nicht gelesen Java Basics - Anfänger-Themen 4
D Grösste Zahl in einer Folge herausfinden. (ULAM) Java Basics - Anfänger-Themen 9
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9
I Array einer Methode wiedergeben Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben