JTable direkt editierenund in Datenbanken speichern

nieselfriem

Bekanntes Mitglied
Hallo!

Es gibt reichlich Beispiele, wie man Daten aus einer Datenbank liest und diese in JTables darstellt. Nun möchte ich gerne die gelesenen Daten direkt in der Tabelle editieren können (im Grundlegenden auch nicht das Thema) um sie dann wieder mittels eines Buttons (Speichern) wieder in der Datenbank speichern zu können. Kennt jemand ein Tutorial was sich mit dieser Thematik beschäftigt. Bisher habe ich es immer so gehalten, dass ich mittels Doppelklick auf die Zeile der Tabelle ein Dialog geöffnet hat und darüber dann die Daten in der Datenbank gespeichert wurden. So richtig ist mir bisher nicht die zündende Idee der Umsetzung ohne diesen Dialog gekommen, da ich es nicht so richtig schaffe die entsprechenden Ereignisse die bearbeitet werden müssen zu kombinieren.

Gruß niesel
 

André Uhres

Top Contributor
Hallo nieselfriem,

was willst du beim Speichern genau machen? Eine Möglichkeit wäre, wenn du auf "Speichern" klickst, dann nimmst du nur die ausgewählte Zeile, verwendest "getValueAt", um die Werte aus den Zellen zu holen und machst damit einen Update auf der Datenbank.

Gruß,
André
 

nieselfriem

Bekanntes Mitglied
Naja eigentlich währe es besser einfach zu ermitteln, welch Zellen editiert worden sind und diese dann zu speichern. Also ich bewege mich die Tabelle rauf und runter, ändere mal hier was, dann mal da was und das wird alles protokolliert und ggf. schon während dessen als QueryString mit den entsprechenden Werten in eine ArrayListe gespeichert. Diese soll dann einfach als Transaktion gespeichert werden. Hat jedoch den Nachteil, dass ich wenn ich in einer Zelle zweimal was ändere, dass erst der erste wert in der DB eingetragen wird und dann der andere. Aber ein anderer Weg fällt mir von Grundkonzept nicht ein. Mein Problem ist, wie ermittel ich welche Zellen wurden nach erstellen der Tabelle editiert um dann die Daten abzufragen.

Gruß und gute Nacht ;)
 

Bib

Mitglied
Hallo,

mein Ansatz wäre ein TableModel zu erstellen das die Daten hält. Das Table Model sollte AbstractTableModel erweitern. Wenn in der JTable 'autoCreateColumnsFromModel' gesetzt ist werden die Daten automatisch in die Tabelle übernommen und synchron gehalten.
Für die Verbindung zur Datenbank muss dann die Ereignisbehandlung noch implementiert werden, so dass auch hier eine automatische Synchronisation stattfindet.
So must Du Dich überhaupt nicht mehr 'zu Fuß' um die Aktualisierung kümmern.

In diesem Zusammenhang ist auch das Thema 'updateable ResultSets' von Interesse.
Der nächste Schritt wäre dann eventuell die Nutzung der JPA (Java Persistence API) die noch eine Abstraktionsebene hinzufügt.

Ersten Überblick hierzu bekommt man über Wikipedia und dann natürlich auch über JAVADOC zum entsprechenden Paket 'javax.persistence'.

Vielleicht wäre das für Dich auch ein Ansatz. Viel Erfolg!

Bib
 

André Uhres

Top Contributor
Den Ansatz von Bib finde ich auch gut.

Zu deinem Ansatz: wir können einen TableModelListener verwenden, den wir an das TableModel hängen.
Das TableModelEvent gibt uns dann Auskunft darüber, welche Zellen editiert wurden.

Gruß,
André
 

nieselfriem

Bekanntes Mitglied
Habe es erst einmal wie folgt lösen können, bzw. einen Ansatz:

Java:
     public void tableChanged(TableModelEvent e) {
        	int row = e.getFirstRow();
        	int column = e.getColumn();
        	MyTableModel model = (MyTableModel)e.getSource();
        	String columnName = model.getColumnName(column);
        	System.out.println("Columname= "+columnName);
        	Object data = model.getValueAt(row, column);
        	System.out.println("Daten="+data);
        }
Die Lösung war auf der Oracle Seite ;)
Ich versuch es erst einmal auf dem herkömmlichen weg und später mit dem anderen vorgeschlagenen Ansatz

gruß niesel
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Swing JTable zeichnet kein vertical Grid AWT, Swing, JavaFX & SWT 6
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
D MySQL Daten in JTable anzeigen AWT, Swing, JavaFX & SWT 2
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
thet1983 Swing MySQL >> JTable AWT, Swing, JavaFX & SWT 5
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
S JTable übernimmt Änderungen nicht AWT, Swing, JavaFX & SWT 2
Y JTable AWT, Swing, JavaFX & SWT 6

Ähnliche Java Themen

Neue Themen


Oben