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:
Mit folgendem Code wollte ich den Listener entfernen:
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
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