Swing JTable - Editierung von Zellen abfangen

Strece

Mitglied
Hallo,

ich arbeite grade an einer JTable die Daten aus einer MySQL DB anzeigt.
Nun möchte ich gerne, das man diese Daten bearbeiten kann und die Änderungen dann in die DB geschrieben wird.

So nach ein wenig googeln bin ich auf den TableModelListener getroffen, dieser scheint ja meine Anforderungen zu erfüllen.

Nun aber das scheint nicht zu funktionieren, mein Problem ist das sich meine Tabelle beim Start des Programm mit den Werten aus der DB füllt, dadurch wird direkt das Listener Event ausgelöst und ich bekomme eine ArrayIndexOutOfBounds Exception und zwar bei der Zeile "Object data = model.getValueAt(row, column);" (siehe unten).

Ich habe dann versucht den Listener bei jedem Refresh der Tabelle zu entfernen und dann wieder aktivieren, aber das klappt leider nicht wie gewollt.

Also derzeit sieht mein Code so aus:

Java:
grdSearch.getModel().addTableModelListener(new javax.swing.event.TableModelListener() {

            public void tableChanged(javax.swing.event.TableModelEvent evt) {
                grdSearchTableChanged(evt);
            }
        });

Java:
private void grdSearchTableChanged(javax.swing.event.TableModelEvent evt) {
        int row = evt.getFirstRow();
        int column = evt.getColumn();
        TableModel model = (TableModel) evt.getSource();
        String columnName = model.getColumnName(column);
        Object data = model.getValueAt(row, column);

        try {
            st.executeUpdate("Update verbindungen Set " + columnName + "= '" + data + "' Where ID = " + grdSearch.getValueAt(row, 0) + ";");
        } catch (SQLException ex) {
            JOptionPane.showMessageDialog(null, ex.getMessage(), "Fehler", JOptionPane.CANCEL_OPTION);
        }
        refresh();
    }

Mit folgendem Code wollte ich den Listener entfernen:
Java:
grdSearch.getModel().removeTableModelListener(grdSearch);

Vielleicht hab ich irgendwo einen Denkfehler oder gehe die Sache falsch an. Hatte auch schon an einen CellEditorListener gedacht, aber ich denke da ist der TableModelListener besser.
Habe auch gelesen, das man den Listener so anpassen kann das er nur bei Änderungen in einer Zelle reagiert, aber so wie ich das gelesen habe, muss man dabei die Zeile und Spalte immer genau angeben. Dies wäre aber nicht schön, da es schon mit jeder Spalte und Zeile funktionieren sollte.

Mfg, Strece
 

Michael...

Top Contributor
Mit folgendem Code wollte ich den Listener entfernen:
Java:
grdSearch.getModel().removeTableModelListener(grdSearch);
Im Codeausschnitt weiter oben wird ein anonymer Listener am TableModel registriert, den kriegt man so nicht weg.

Grundsätzlich kann man das TableEvent aber auch "fragen" was für eine Änderung vorgenommen wurde. So wie ich das verstanden habe sind ja nur Updates interessant und keine Inserts.
 

Strece

Mitglied
Ja genau, es gut nur um Updates. Alle Änderungen werden per Update Statement in die DB gschrieben und es soll auch immer nur eine Zelle gleichzeitig bearbeitet werden, nicht ganze Zeilen.

Das würde ja heißen ich müsste überprüfe ob eine Zelle geändert wurde, auf der Seite vom TableModelEvent wäre da ja entweder
TableModelEvent(source, 1); // Row 1 changed oder
TableModelEvent(source, 2, 2, 6); // Cell at (2, 6) changed

Würde er aber nicht beim ersten auch den Listener beim Start aufrufen da ich ja erstmal aus der DB alle Daten auslese und somit alle Zeilen einfüge?

Beim zweiten sehe ich als Problem die Begrenzung, so wie ich das verstanden habe würde er z.B. darauf achten wenn sich eine Zelle zwischen den Zeilen 2 und 6 ändert oder liege ich da falsch? Weil die Anzahl an Zeilen variiert ja sehr stark in einer DB.

Mfg, Strece

EDIT: Habe mal wieder zu schnell geschrieben als gedacht, habe grade weiter unten etwas über Update gelesen.
Java:
public static final int UPDATE

Ist es damit möglich herauszufiltern ob ein Update stattgefunden hat?

EDIT2:
So habe nun den Code folgendermaßen erweitert:
Java:
private void grdSearchTableChanged(javax.swing.event.TableModelEvent evt) {
        if(evt.getType() == 0)
        {
            int row = evt.getFirstRow();
            int column = evt.getColumn();
            TableModel model = (TableModel) evt.getSource();
            String columnName = model.getColumnName(column);
            Object data = model.getValueAt(row, column);

            try {
                st.executeUpdate("Update verbindungen Set " + columnName + "= '" + data + "' Where ID = " + grdSearch.getValueAt(row, 0) + ";");
            } catch (SQLException ex) {
                JOptionPane.showMessageDialog(null, ex.getMessage(), "Fehler", JOptionPane.CANCEL_OPTION);
            }
            refresh();
        }
    }

Aber dennoch bekomme ich beim Start eine ArrayIndexOutOfBounds Exception bei der gleichen Zeile.
 
Zuletzt bearbeitet:

Strece

Mitglied
Ok Problem hat sich erledigt, habe nach ein wenig rumtesten die Lösung gefunden.
Mir fehlte nur eine weitere Abfrage ob alle Columns geändert wurden oder nicht, also meine Lösung sieht so aus:

Java:
if (evt.getType() == TableModelEvent.UPDATE) {
            int row = evt.getFirstRow();
            int column = evt.getColumn();
            if (column != TableModelEvent.ALL_COLUMNS)
            {
                TableModel model = (TableModel)evt.getSource();
                String columnName = model.getColumnName(column);
                Object data = model.getValueAt(row, column);

                System.out.println("Zeile: " + row);
                System.out.println("Spalte: " + column + " " + columnName);
                System.out.println("Wert: " + data);
           }
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
GilbertGrape JTable mit Combobox-Editierung schon nach einem Klick AWT, Swing, JavaFX & SWT 7
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