Это мой 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;
}
Я вызову этот метод, чтобы получить данные из базы данных и поместить их в табличную модель.
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);
}
В настоящее время я использовал этот метод для обновления таблицы после обновления данных таблицы. Я сначала уберу со стола
DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
tableModel.setRowCount(0);
а затем снова реструктурируйте модель таблицы, чтобы она обновила jTable. Но я подумал, есть ли лучшие практики или лучший способ сделать это?
DefaultTableModel.addRow
уже должна справиться с этим ... Разве ваша таблица не обновляетсяaddRow
?setValueAt
,DefaultTableModel
запускает событие.javax.swing.table.AbstractTableModel
, поскольку интерфейсTableModel
не имеет метода, упомянутого вышеБолее быстрый способ для вашего случая:
jTable.repaint(); // Repaint all the component (all Cells).
Оптимизированный способ при смене одной или нескольких ячеек:
((AbstractTableModel) jTable.getModel()).fireTableCellUpdated(x, 0); // Repaint one cell.
источник
попробуй это
public void setUpTableData() { DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel(); /** * additional code. **/ tableModel.setRowCount(0); /**/ 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); /** * additional code. **/ tableModel.fireTableDataChanged(); /**/ }
источник
DefaultTableModel dm = (DefaultTableModel)table.getModel(); dm.fireTableDataChanged(); // notifies the JTable that the model has changed
источник
Не лучше ли использовать,
java.util.Observable
иjava.util.Observer
это приведет к обновлению таблицы?источник
Я сделал это так в моем Jtable - автообновление через 300 мс;
DefaultTableModel tableModel = new DefaultTableModel(){ public boolean isCellEditable(int nRow, int nCol) { return false; } }; JTable table = new JTable(); Timer t = new Timer(300, new ActionListener() { @Override public void actionPerformed(ActionEvent e) { addColumns(); remakeData(set); table.setModel(model); } }); t.start(); private void addColumns() { model.setColumnCount(0); model.addColumn("NAME"); model.addColumn("EMAIL");} private void remakeData(CollectionType< Objects > name) { model.setRowCount(0); for (CollectionType Objects : name){ String n = Object.getName(); String e = Object.getEmail(); model.insertRow(model.getRowCount(),new Object[] { n,e }); }}
Я сомневаюсь, что он подойдет для большого количества объектов, например, более 500, единственный способ - реализовать TableModelListener в вашем классе, но я не понимал, как его правильно использовать. посмотрите http://download.oracle.com/javase/tutorial/uiswing/components/table.html#modelchange
источник