Java GUI JTable'刷新'

时间:2017-01-22 17:56:55

标签: java swing jtable

我正在制作一个GUI并且它包含一个JPanel,在JPanel内部有一个JTable,我想要做的是:当我点击一个按钮时,它们都会出现(因为我正在使用CardLayout)。代码:

 private void teGjithaButtonActionPerformed(java.awt.event.ActionEvent evt) {                                               
try {
    parentPanel.setVisible(true);
    parentPanel.removeAll();
    parentPanel.add(tgjPanel);
    parentPanel.repaint();
    parentPanel.revalidate();
    listAllCurtains();
} catch (SQLException ex) {
    Logger.getLogger(MainBrillant.class.getName()).log(Level.SEVERE, null, ex);
}

listAllCurtains()的代码:

public void listAllCurtains() throws SQLException {
    DefaultTableModel deftm = (DefaultTableModel) allTable.getModel();

    if (deftm.getRowCount() != 0) {
        deftm.setRowCount(0);
    }

    stm = (Statement) conn.createStatement();
    ResultSet rs = stm.executeQuery("select * from customerregister.curtain inner join curtainrel on curtain.code = curtainrel.curtainCode;");
    while (rs.next()) {
        String shifra = rs.getString("code");
        String ngjyra = rs.getString("color");
        String emri = rs.getString("name");
        double cmimi = rs.getDouble("price");
        double sasia = rs.getDouble("amount");
        allCurtains.add(new Curtain(shifra, ngjyra, emri, cmimi, sasia));
    }

    Object[] row = new Object[5];


    for (int i = 0; i < allCurtains.size(); i++) {
        row[0] = allCurtains.get(i).getShifra();
        row[1] = allCurtains.get(i).getEmri();
        row[2] = allCurtains.get(i).getNgjyra();
        row[3] = allCurtains.get(i).getCmimi();
        row[4] = allCurtains.get(i).getSasia();
        deftm.addRow(row);
    }

}

问题在于,当我重新点击按钮时,尽管有这部分代码可以确保数据不重复:

if (deftm.getRowCount() != 0) {
    deftm.setRowCount(0);
}

每次单击按钮时,它仍然会继续将相同的数据插入表中。我无法弄清楚为什么会这样,我真的很感谢你的帮助。

1 个答案:

答案 0 :(得分:2)

您的问题可能是由于此变量:allCurtains。您没有先清除它,并继续添加它,因此所有旧数据仍由它保存。

在您的方法开始时,可​​以通过allCurtains.clear();清除此集合。

public void listAllCurtains() throws SQLException {
    DefaultTableModel deftm = (DefaultTableModel) allTable.getModel();

    if (deftm.getRowCount() != 0) {
        deftm.setRowCount(0);
    }
    allCurtains.clear(); // ***** add this *****

    // ..... more code

其他问题:您说明您正在使用CardLayout,但这不是CardLayout的使用方式。