Esta es mi jTable
private JTable getJTable() {
String[] colName = { "Name", "Email", "Contact No. 1", "Contact No. 2",
"Group", "" };
if (jTable == null) {
jTable = new JTable() {
public boolean isCellEditable(int nRow, int nCol) {
return false;
}
};
}
DefaultTableModel contactTableModel = (DefaultTableModel) jTable
.getModel();
contactTableModel.setColumnIdentifiers(colName);
jTable.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
return jTable;
}
Llamaré a este método para recuperar los datos de la base de datos y ponerlos en el modelo de tabla
public void setUpTableData() {
DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
ArrayList<Contact> list = new ArrayList<Contact>();
if (!con.equals(""))
list = sql.getContactListsByGroup(con);
else
list = sql.getContactLists();
for (int i = 0; i < list.size(); i++) {
String[] data = new String[7];
data[0] = list.get(i).getName();
data[1] = list.get(i).getEmail();
data[2] = list.get(i).getPhone1();
data[3] = list.get(i).getPhone2();
data[4] = list.get(i).getGroup();
data[5] = list.get(i).getId();
tableModel.addRow(data);
}
jTable.setModel(tableModel);
}
Actualmente estaba usando este método para actualizar la tabla después de actualizar los datos de la tabla. Primero limpiaré la mesa
DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
tableModel.setRowCount(0);
y luego reestructurar el modelo de tabla nuevamente para que actualice la tabla jTable. Pero estaba pensando, ¿existen mejores prácticas o una mejor manera de hacerlo?
DefaultTableModel.addRow
ya debería manejar eso ... ¿No es tu tabla actualizada poraddRow
?setValueAt
,DefaultTableModel
dispara el evento.javax.swing.table.AbstractTableModel
, ya que la interfazTableModel
no tiene el método mencionado anteriormente