이것은 내 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을 새로 고칩니다. 하지만 모범 사례 나 더 나은 방법이 있다고 생각했습니다.
답변
JTable
데이터 변경에 대해 알리려면
tableModel.fireTableDataChanged()
로부터 문서 :
테이블 행의 모든 셀 값이 변경되었을 수 있음을 모든 리스너에게 알립니다. 행 수도 변경되었을 수 있으며 JTable은 처음부터 테이블을 다시 그려야합니다. 테이블의 구조 (열 순서와 같음)는 동일한 것으로 간주됩니다.
답변
케이스에 대한 더 빠른 방법은 다음과 같습니다.
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에서 300ms 후에 자동 새로 고침을 수행했습니다.
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 를 참조하십시오.