猿问

JTable如何在插入删除或更新数据后刷新表模型。

JTable如何在插入删除或更新数据后刷新表模型。

这是我的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。但我在想是否有最好的做法或更好的方法呢?


慕慕森
浏览 1695回答 3
3回答

慕哥9229398

如果您想通知您JTable有关数据的更改,请使用tableModel.fireTableDataChanged()从文档:通知所有侦听器表中行中的所有单元格值都可能已更改。行数也可能已更改,JTable应从头开始重绘表。假设表的结构(按列的顺序)是相同的。

摇曳的蔷薇

更快的方法是:&nbsp;&nbsp;&nbsp;&nbsp;jTable.repaint();&nbsp;//&nbsp;Repaint&nbsp;all&nbsp;the&nbsp;component&nbsp;(all&nbsp;Cells).当一个或几个细胞改变时的优化方式:&nbsp;&nbsp;&nbsp;&nbsp;((AbstractTableModel)&nbsp;jTable.getModel()).fireTableCellUpdated(x,&nbsp;0);&nbsp;//&nbsp;Repaint&nbsp;one&nbsp;cell.

Helenr

试试这个public&nbsp;void&nbsp;setUpTableData()&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;DefaultTableModel&nbsp;tableModel&nbsp;=&nbsp;(DefaultTableModel)&nbsp;jTable.getModel(); &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;additional&nbsp;code. &nbsp;&nbsp;&nbsp;&nbsp;**/ &nbsp;&nbsp;&nbsp;&nbsp;tableModel.setRowCount(0); &nbsp;&nbsp;&nbsp;&nbsp;/**/ &nbsp;&nbsp;&nbsp;&nbsp;ArrayList<Contact>&nbsp;list&nbsp;=&nbsp;new&nbsp;ArrayList<Contact>(); &nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(!con.equals("")) &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;list&nbsp;=&nbsp;sql.getContactListsByGroup(con); &nbsp;&nbsp;&nbsp;&nbsp;else &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;list&nbsp;=&nbsp;sql.getContactLists(); &nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;<&nbsp;list.size();&nbsp;i++)&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;String[]&nbsp;data&nbsp;=&nbsp;new&nbsp;String[7]; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;data[0]&nbsp;=&nbsp;list.get(i).getName(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;data[1]&nbsp;=&nbsp;list.get(i).getEmail(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;data[2]&nbsp;=&nbsp;list.get(i).getPhone1(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;data[3]&nbsp;=&nbsp;list.get(i).getPhone2(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;data[4]&nbsp;=&nbsp;list.get(i).getGroup(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;data[5]&nbsp;=&nbsp;list.get(i).getId(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;tableModel.addRow(data); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;jTable.setModel(tableModel); &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;additional&nbsp;code. &nbsp;&nbsp;&nbsp;&nbsp;**/ &nbsp;&nbsp;&nbsp;&nbsp;tableModel.fireTableDataChanged(); &nbsp;&nbsp;&nbsp;&nbsp;/**/}
随时随地看视频慕课网APP

相关分类

Java
我要回答