我正在尝试使用汽车品牌,型号填充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();
}
答案 0 :(得分:1)
当我进入桌子的多辆车时,新车打印到桌面上,但我输入的以前的车也重印了
在开始向其中添加数据之前,您需要清除TableModel中的数据。
基本代码应该是这样的:
DefaultTableModel model = (DefaultTableModel)table.getModel();
model.setRowCount(0);
while (rs.next())
{
...
model.addRow(...);
}
或者,不是每次执行插入时都从数据库中检索所有数据,只需同时将数据添加到表中:
pstmt.executeUpdate();
model.addRow(...);