java - jTable数据库重复值

时间:2017-12-02 02:45:48

标签: java mysql database swing jdbc

我正在尝试使用汽车品牌,型号填充java数据库,如果它们可用但我有一个大问题。当我进入桌子的多辆车时,新车打印到桌子上,但我输入的以前的车也重印了 [Issue.png] [1]。所以首先我进入法拉利恩佐,然后我进入了特斯拉S,但法拉利恩佐正在重复。

我知道问题不在于将汽车添加到数据库,因为如果我查看数据库,它只会显示我输入的两个[DatabasePic.png] [2]。我知道我的问题在于如何将我的车进入JTable。我的方法如下......

ButtonClickEvent:

private void refreshbtnMouseClicked(java.awt.event.MouseEvent evt) {                                        
    try {
        String Brand = brandlbl.getText();
        String Model = modellbl.getText();
        Boolean Available = false;
        switch (availabilitybox.getSelectedItem().toString()) {
            case "True":
                Available = true;
                break;
            case "False":
                Available = false;
                break;
        }
        InsertApp nw = new InsertApp();
        nw.insert(Brand, Model, Available);
        nw.refreshDatabase(jTable1);
    } catch (SQLException ex) {
        Logger.getLogger(Window.class.getName()).log(Level.SEVERE, null, ex);
    }
}

插入方法:

public void insert(String brand, String model, Boolean available) {
    String sql = "INSERT INTO CARDATA(brand,model,available) VALUES(?,?,?)";

    try (Connection conn = this.connect();
            PreparedStatement pstmt = conn.prepareStatement(sql)) {

        pstmt.setString(1, brand);
        pstmt.setString(2, model);
        pstmt.setBoolean(3, available);

        pstmt.executeUpdate();
    } catch (SQLException e) {

        System.out.println(e.getMessage());
    }

}

刷新我的数据库:

public void refreshDatabase(JTable table) throws SQLException {
    Connection con = connect();
    String SQL = "SELECT * FROM CARDATA";
    Statement stmt = con.createStatement();
    ResultSet rs = stmt.executeQuery(SQL);
    int col = rs.getMetaData().getColumnCount();
    System.out.println(col);
    while (rs.next()) {
        Object[] rows = new Object[col];
        for (int i = 1; i <= col; i++) {
            rows[i - 1] = rs.getObject(i);
        }
        ((DefaultTableModel) table.getModel()).insertRow(rs.getRow() - 1, rows);
    }
    con.close();
    rs.close();
    stmt.close();
}

1 个答案:

答案 0 :(得分:1)

  

当我进入桌子的多辆车时,新车打印到桌面上,但我输入的以前的车也重印了

在开始向其中添加数据之前,您需要清除TableModel中的数据。

基本代码应该是这样的:

DefaultTableModel model = (DefaultTableModel)table.getModel();
model.setRowCount(0);

while (rs.next()) 
{
    ...

    model.addRow(...);
}

或者,不是每次执行插入时都从数据库中检索所有数据,只需同时将数据添加到表中:

pstmt.executeUpdate();
model.addRow(...);