JTable aus MySQL DB updaten - Live

ldeep

Mitglied
Hey zusammen

Ich habe eine ganz generelle Frage:

Ich fülle eine JTable mit Daten aus einem ResultSet von einer Select-Abfrage. Nun prüfe ich mit einem Thread, ob geänderte oder neue Daten in die MySQL Tabelle gekommen sind. Falls dies zutrifft, sollen die neuen Werte unten angefügt werden und die aktualisierten Felder aktualisiert werden.

Ich möchte dies aber durchführen, ohne dass der User des Programms etwas davon merkt.. Das heisst, es soll bei einem Update/Neuen Datensatz nicht die ganze JTable neu gezeichnet werden.

Gibt es einen Lösungsansatz in diese Richtung oder kann ich das direkt vergessen?

Danke für Hilfe & Tipps
 

Ebenius

Top Contributor
Das Tabellenmodell bietet alle notwendigen Events, um Tabellenzellen zu aktualisieren, Zeilen und Spalten hinzuzufügen oder selbige zu entfernen. Wie befüllst Du denn die Tabelle initial? Bzw. welches Tabellenmodell wird denn benutzt?


Vorab gleich der Hinweis: Da die Datenbankaktualisierung im Hintergrund läuft (also nicht im AWT-EventDispatchThread aka. EDT) muss die Aktualisierung des Tabellenmodells auf den EDT ausgelagert werden. Entweder man verwendet hierzu gleich die SwingWorker-Klasse. Das geschilderte Szenario klingt mir aber nicht nach einem Kandidaten dafür. Oder man nutzt [c]SwingUtilities.invokeLater(Runnable)[/c] bzw. [c]SwingUtilities.invokeAndWait(Runnable)[/c] und aktualisiert die Tabellenmodelldaten aus der [c]run()[/c]-Methode des übergebenen [c]Runnable[/c].


Ebenius
 

ldeep

Mitglied
Das Tabellenmodell bietet alle notwendigen Events, um Tabellenzellen zu aktualisieren, Zeilen und Spalten hinzuzufügen oder selbige zu entfernen. Wie befüllst Du denn die Tabelle initial? Bzw. welches Tabellenmodell wird denn benutzt?


Vorab gleich der Hinweis: Da die Datenbankaktualisierung im Hintergrund läuft (also nicht im AWT-EventDispatchThread aka. EDT) muss die Aktualisierung des Tabellenmodells auf den EDT ausgelagert werden. Entweder man verwendet hierzu gleich die SwingWorker-Klasse. Das geschilderte Szenario klingt mir aber nicht nach einem Kandidaten dafür. Oder man nutzt [c]SwingUtilities.invokeLater(Runnable)[/c] bzw. [c]SwingUtilities.invokeAndWait(Runnable)[/c] und aktualisiert die Tabellenmodelldaten aus der [c]run()[/c]-Methode des übergebenen [c]Runnable[/c].


Ebenius


Noch zu Deiner Frage: Ich nehme aktuell die Daten aus der DB und speicher sie in einer Treemap.. aber das ist halt einfach so entstanden, ohne spezielle Gedanken. Ich kümmere mich nun mal um das Tablemodell. Sieht sehr interessant aus. Für die Concurrency Sache brauche ich dann evt. noch etwas Hilfe.. :noe:
 

ldeep

Mitglied
Ebenius: Habe noch eine Frage: Ich brauche für die Updated ja irgend einen Anhaltspunkt, welche Reihe/Feld/Spalte ich updaten soll. Dafür könnte ich die ganze JTable nach nem Wert durchsuchen - ich fürchte aber, dass das wesentlich eleganter geht? Hast Du da ein Tipp dazu? Habe nix gscheites gefunden.
 

Ebenius

Top Contributor
Auf irgendeine Art musst Du schon herausfinden, ob es einen Eintrag schon gibt oder nicht. Wie genau Du das machst, hängt natürlich davon ab, wie Deine Datenstruktur ausschaut. Beschreib doch mal den Inhalt der Tabelle, dann kann man da weiter reden!

Ebenius
 

ldeep

Mitglied
MySQL Tabelle sieht so aus:

Ich habe eine Tabelle mit Einträgen, die stets grösser wird durch neue Einträge. Alte Einträge werden archiviert.

Die Tabellenstruktur ist etwa so:

id, kundennummer, ort, datum, timestamp

diese einträge werden nun in eine jtable übernommen. da es mehrere user gibt, können mehrere gleichzeitig arbeiten und somit gibt es im laufenden betrieb updates. dann möchte ich per fire die aktualisierten felder aktualisieren. dh ich muss also wissen, wo ein neuer wert eingefügt werden muss.. in mysql nutze ich natürlich WHERE - aber das gibts bei jtable ja nicht.. ich bräuchte also irgendwie die möglichkeit einen zeiger z usetzen den ich mit der DB vergleichen kann.. z bsp die kundennummer.. dass der wert mit dem der db verglichen wird, zeilen zahl ausgibt und dann diese zeile per update neu gezeichnet wird (natürlich vorher noch der mysql select auf diese row)

hoffe du verstehts was ich meine :)

Meine Idee wäre etwa folgende:

TreeMap<Integer,Object[]>

Integer ist der Zeilenzähler, das Object array enthält die einzelnen DB Zeilen. Dann schreibe ich das alles in die JTable. Wenn nun ein Update kommt, habe ich die Möglichkeit die Zeilenzahl per Vergleich mit der Treemap herauszukriegen und dann entsprechen das Update zu machen. Ob das sauber ist und überhaupt machbar - keine Ahnung.
 
Zuletzt bearbeitet:

ldeep

Mitglied
reup :D

Ich habe mittlerweile vieles rausgefunden und geklärt.

Aber da ist eine Sache: Atm habe ich Objekt Arrays für die DB Daten. Das ist aber schlecht, weil ich die Grösse bei einem neuen Auftrag nicht beeinflussen kann. Wie ginge es besser? Mit ArrayList? Und wie ich mit dem AbstractModel eine neue Zeile hinzufügen kann ist mir auch schleierhaft. Hat da jemand Erfahrung mit?
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
D MySQL Daten in JTable anzeigen AWT, Swing, JavaFX & SWT 2
thet1983 Swing MySQL >> JTable AWT, Swing, JavaFX & SWT 5
thet1983 Swing JTable mit MySQL Datenbank AWT, Swing, JavaFX & SWT 14
H JTable mySQL Update AWT, Swing, JavaFX & SWT 8
A JTable mit MySQL Datenbank füllen AWT, Swing, JavaFX & SWT 12
J Drag und drop aus einer JTable - bitte um Unterstützung AWT, Swing, JavaFX & SWT 2
S HPRO und UPRO gemeinsame JTABLE gemeinsamer RENDERER ? AWT, Swing, JavaFX & SWT 1
F Swing JTable - MultiHeader inkl. Eingabemöglichkeit AWT, Swing, JavaFX & SWT 1
S JTable - Feldinhalte anzeigen AWT, Swing, JavaFX & SWT 15
D Swing JTable Spaltenbreite AWT, Swing, JavaFX & SWT 1
W Gibt es einen "automatischen Listener" in Swing oder JTable oder der ATM-Klasse? AWT, Swing, JavaFX & SWT 14
G jTable - getSelectedRow() AWT, Swing, JavaFX & SWT 3
I JTable mit einem Button zu einer Detail Seite springen AWT, Swing, JavaFX & SWT 4
P JTable Listener für die Änderung einzelner Zellen oder Rows AWT, Swing, JavaFX & SWT 2
D Tastaturabfragen CTRL+t, CTRL+E bei eine JTable, bestehend aus JTextAteas AWT, Swing, JavaFX & SWT 4
P Checkboxes in JTable nicht editable AWT, Swing, JavaFX & SWT 9
F Best-Practise: JTable Text in Zelle zu groß AWT, Swing, JavaFX & SWT 2
izoards JTable in CSV File schreiben... AWT, Swing, JavaFX & SWT 23
Kohl Jedes Objekt einer JTable um ein Zeichen verkürzen AWT, Swing, JavaFX & SWT 7
I JTable, DefaultTableModel, zwei Zahlen multiplizieren. AWT, Swing, JavaFX & SWT 26
M JTABLE / wie oft wurde gewürfelt. AWT, Swing, JavaFX & SWT 1
F JTable vergrößern AWT, Swing, JavaFX & SWT 2
H JTable: Diverse NullPointer-Exceptions zur Laufzeit AWT, Swing, JavaFX & SWT 3
J Swing Werte des JTable werden nicht angezeigt AWT, Swing, JavaFX & SWT 9
T Swing JTable cellRenderer mit jpg Hintergrundfarbe lässt sich nicht ändern. AWT, Swing, JavaFX & SWT 1
HoT Einzelne Zelle in JTable Rahmen unten setzen AWT, Swing, JavaFX & SWT 24
B JTable Zellen zusammenfügen AWT, Swing, JavaFX & SWT 3
M Swing Cell Renderer für Zeilenumbruch in JTable AWT, Swing, JavaFX & SWT 0
H JTable im JSplitPane darstellen AWT, Swing, JavaFX & SWT 2
MadMax2506 Swing JTable lädt sehr lange AWT, Swing, JavaFX & SWT 1
D Zeilenumbruch in einer JTable AWT, Swing, JavaFX & SWT 9
R Swing JTable und Spaltenausrichtung AWT, Swing, JavaFX & SWT 8
G JTable füllen AWT, Swing, JavaFX & SWT 1
H JTable TableCellEditor-Problem AWT, Swing, JavaFX & SWT 0
W Swing JTable Zeilenumbruch innerhalb einer Zelle AWT, Swing, JavaFX & SWT 3
J Datensatz in jTable ausgeben AWT, Swing, JavaFX & SWT 3
M Swing Automatischer Editorstart in JTable-Zelle AWT, Swing, JavaFX & SWT 5
ralfb1105 Swing JTable aktualisieren AWT, Swing, JavaFX & SWT 5
adiko01 JTable: Nur markierte Zeilen aus der Tabelle in CSV exportiern AWT, Swing, JavaFX & SWT 9
M JTable.setDefaultRenderer(...) greift nicht AWT, Swing, JavaFX & SWT 0
J JTable: Eingabe in Tabellenzelle korrigieren AWT, Swing, JavaFX & SWT 4
T Problem mit JTable Sortierung AWT, Swing, JavaFX & SWT 2
D JTable nach INSERT aktualisieren /refreshen AWT, Swing, JavaFX & SWT 1
H Swing Jtable extra spalte AWT, Swing, JavaFX & SWT 6
S Swing Rechteck über JTable zeichnen (per MouseListener) AWT, Swing, JavaFX & SWT 1
S Swing Mal wieder JTable Ansicht aktualisieren AWT, Swing, JavaFX & SWT 10
A JTable mit Daten füllen AWT, Swing, JavaFX & SWT 1
VfL_Freak Swing Einzelne Zeile in jTable selektieren klappt nicht AWT, Swing, JavaFX & SWT 7
N AWT jTable CellRenderer AWT, Swing, JavaFX & SWT 6
T Swing JTable valueChanged datensatz löschen AWT, Swing, JavaFX & SWT 1
0 Swing JTable aus anderer Klasse updaten AWT, Swing, JavaFX & SWT 5
S Jtable defaultRenderer wohin damit ? AWT, Swing, JavaFX & SWT 23
T Swing JTable / FocusListener AWT, Swing, JavaFX & SWT 0
it_is_all Warum wird die JTable im JDialog nicht angezeigt? AWT, Swing, JavaFX & SWT 1
L Swing JTable im Panel darstellen AWT, Swing, JavaFX & SWT 8
T Swing Double Click bei Buttons in JTable AWT, Swing, JavaFX & SWT 9
J addRow bei JTable AWT, Swing, JavaFX & SWT 6
M Jtable gibt -1 wert bei selectedRow und Column AWT, Swing, JavaFX & SWT 3
Meeresgott Swing JTable AWT, Swing, JavaFX & SWT 4
J JTable Selection Listener funktioniert nicht AWT, Swing, JavaFX & SWT 4
C Swing Daten in JTable wiedergeben per TableModel und MVC Pattern AWT, Swing, JavaFX & SWT 16
Z Swing Drag&Drop zwischen JTable und JTree AWT, Swing, JavaFX & SWT 4
Thallius JTable dynamisch Spaltenanzahl verändern AWT, Swing, JavaFX & SWT 2
Thallius JTable dynamisch laden? AWT, Swing, JavaFX & SWT 2
B Swing JTable sortieren AWT, Swing, JavaFX & SWT 2
T Swing JTable auslesen und befüllen AWT, Swing, JavaFX & SWT 8
B JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 1
J JTable und Suchlogik AWT, Swing, JavaFX & SWT 4
Viktim Swing JTable mit Tab verlassen AWT, Swing, JavaFX & SWT 1
F Swing Spaltenbreite einer Column eines JTable auslesen AWT, Swing, JavaFX & SWT 5
Viktim Swing JTable Mit Tab druch Zeilen Wechseln AWT, Swing, JavaFX & SWT 5
Thallius Warum refrehsed mein JTable nicht? AWT, Swing, JavaFX & SWT 5
Ghostman1711 Hinzufügen ausgewählter Dateinen des Filechoosers zu einem JTable AWT, Swing, JavaFX & SWT 9
S Swing JTable - Einzelne Rows einfärben AWT, Swing, JavaFX & SWT 11
M Wert einer Zelle aus JTable ziehen AWT, Swing, JavaFX & SWT 4
K JTable getValueAt() klappt nicht immer AWT, Swing, JavaFX & SWT 1
K JTable in extra Klasse, Zugriff in einer anderen klasse nicht möglich AWT, Swing, JavaFX & SWT 26
B Swing Tabelle(JTable) filtern swing GUI AWT, Swing, JavaFX & SWT 3
P JTable - bei Eingabe Selektion AWT, Swing, JavaFX & SWT 0
P Fokus auf Zelle in JTable AWT, Swing, JavaFX & SWT 1
S Swing Deselektion in JTable verhindern AWT, Swing, JavaFX & SWT 0
D Problem mit JTable AWT, Swing, JavaFX & SWT 1
N Swing Print JTable mit AbstractTableModel AWT, Swing, JavaFX & SWT 1
Ananaskirsche Swing jTable Reihen zuviel eingefügt AWT, Swing, JavaFX & SWT 12
P im JTable die Schriftfarbe ändern AWT, Swing, JavaFX & SWT 19
T Swing JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 4
S Dreiecke in bestimmte Zellen einer JTable AWT, Swing, JavaFX & SWT 9
LexeB4F Zelle in JTable gezielt einfärben AWT, Swing, JavaFX & SWT 4
LexeB4F JTable mehrere Zelle selektieren und inhalte Löschen.. Ideen gesucht AWT, Swing, JavaFX & SWT 1
D Swing JTable Renderer Grafikfehler AWT, Swing, JavaFX & SWT 0
K Swing JTable mit ImageIcon und Text in einer Zelle AWT, Swing, JavaFX & SWT 1
M Swing JTable GroupableHeader Background Color AWT, Swing, JavaFX & SWT 4
K Swing JTable updaten AWT, Swing, JavaFX & SWT 9
J JTable bounds ändern durch resizing des Fensters AWT, Swing, JavaFX & SWT 9
F JTable Zellen-Hintergrund ändern AWT, Swing, JavaFX & SWT 7
O JTable linksbündig drucken (nicht der Zelleninhalt) AWT, Swing, JavaFX & SWT 2
Crazynet xls Datei in JTable AWT, Swing, JavaFX & SWT 3
O JTable ohne Rahmen printen AWT, Swing, JavaFX & SWT 3
L Swing JTable refresht die Column Namen nicht AWT, Swing, JavaFX & SWT 0
K JTable komplett durch andere ersetzen AWT, Swing, JavaFX & SWT 4

Ähnliche Java Themen

Neue Themen


Oben