为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

慕慕森 2019-08-12 16:28:44
JTable如何在插入删除或更新数据后刷新表模型。这是我的jTableprivate 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。但我在想是否有最好的做法或更好的方法呢?
查看完整描述

3 回答

?
慕哥9229398

TA贡献1877条经验 获得超6个赞

如果您想通知您JTable有关数据的更改,请使用
tableModel.fireTableDataChanged()

文档

通知所有侦听器表中行中的所有单元格值都可能已更改。行数也可能已更改,JTable应从头开始重绘表。假设表的结构(按列的顺序)是相同的。


查看完整回答
反对 回复 2019-08-12
?
摇曳的蔷薇

TA贡献1793条经验 获得超6个赞

更快的方法是:

    jTable.repaint(); // Repaint all the component (all Cells).

当一个或几个细胞改变时的优化方式:

    ((AbstractTableModel) jTable.getModel()).fireTableCellUpdated(x, 0); // Repaint one cell.


查看完整回答
反对 回复 2019-08-12
?
Helenr

TA贡献1780条经验 获得超4个赞

试试这个

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();
    /**/}


查看完整回答
反对 回复 2019-08-12
  • 3 回答
  • 0 关注
  • 1693 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信