JAVA:How 到 update/refresh Table 对数据库进行更改后

JAVA:How to update/refresh Table after changes made into database

我是 java 和 DBMS 的新手。当用户单击相同的按钮以显示 JTable 以及将数据写入数据库后(单击写入按钮时),在对 H2 数据库进行任何更改后,我正在尝试 update/refresh JTable。我尝试了一些方法并阅读了一些帖子,但找不到对我的程序至关重要的任何内容。下面的代码说明了我的问题。

这是用来从数据库中读取并显示在 JTable 上的方法

public void readActiveData() throws IOException, InstantiationException, IllegalAccessException, SQLException {       

    try {
        st = conn.createStatement();
    } catch (SQLException sqlex) {
        JOptionPane.showMessageDialog(null, "Can't connect to DB. " + sqlex);
        dispose();
    }

    try {
        rs = st.executeQuery("SELECT * FROM main_data WHERE expirationDate > NOW() + 1;");
        rs.beforeFirst();

        while (rs.next()) {
            int id = rs.getInt(1);
            String ovogNer = rs.getString(2);
            String regNum = rs.getString(3);
            String itemName = rs.getString(4);
            String note = rs.getString(5);
            int zHemjee = rs.getInt(6);
            int hvv = rs.getInt(7);
            int hugatsaa = rs.getInt(8);
            today = rs.getDate(9);
            int totalPay = rs.getInt(10);
            expirationDate = rs.getDate(11);
            rows++;
        }
        regData = new Object[rows][11];

        Object[] Colheads = {"Бүртгэлийн дугаар", "Овог нэр", "Регистрийн дугаар", "Барьцаа",
             "Тэмдэглэл", "Зээлийн хэмжээ", "Хүү (%)", "Хугацаа", "Огноо", "Нийт төлөх", "Дуусах хугацаа"};

        rs = st.executeQuery("SELECT * FROM main_data WHERE expirationDate >   NOW() + 1;");

        for (int i1 = 0; i1 < rows; i1++) {
            rs.next();

            for (int j1 = 0; j1 < 11; j1++) {
                regData[i1][j1] = rs.getString(j1 + 1);
            }
        }
        model = new DefaultTableModel(regData, Colheads);
        table = new JTable(model);
        int v = ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED;
        int h = ScrollPaneConstants.HORIZONTAL_SCROLLBAR_AS_NEEDED;
        JScrollPane jsp = new JScrollPane(table, v, h);
        activeDataPanel.add(jsp);
        rs.close();
        st.close();
        conn.close();
    }

这是我用来将数据写入数据库的方法

public void writeDataIntoDB() throws InstantiationException, IllegalAccessException {

    ResultSet rs = null;
    Connection conn = null;
    Statement st = null;
    PreparedStatement pst = null;

    final String URL = "jdbc:h2:~/registDB";
    final String USER = "admin";
    final String PASS = "password";
    LocalDate currentDate = LocalDate.now();
    String input = hugatsaaFld.getText();
    long addDays = Long.parseLong(input);
    expiration = currentDate.plusDays(addDays);
    expirationDate = java.sql.Date.valueOf(expiration);

    try {

        Class.forName("org.h2.Driver").newInstance();

        conn = DriverManager.getConnection(URL, USER, PASS);

        String sql = "INSERT INTO main_data(ovogNer,regNum,itemName,note,zHemjee,hvv,hugatsaa,date,totalPay,expirationDate)"
                + "VALUES"
                + "(?,?,?,?,?,?,?,?,?,? )";
        pst = conn.prepareStatement(sql);
        pst.setString(1, getOvogNer());
        pst.setString(2, getRegNum());
        pst.setString(3, getItemName());
        pst.setString(4, getNote());
        pst.setInt(5, +getzHemjee());
        pst.setInt(6, +getHvv());
        pst.setLong(7, +getHugatsaa());
        pst.setDate(8, java.sql.Date.valueOf(LocalDate.now()));
        pst.setDouble(9, getTotalPay());
        pst.setDate(10, expirationDate);
        pst.executeUpdate();
        pst.close();
        conn.close();
    } catch (SQLException se) {
        JOptionPane.showMessageDialog(null, "Error: " + se);
    } catch (ClassNotFoundException ex) {
        ex.printStackTrace();
    }
}

这个问题已经回答here

但这归结为清除和重新呈现您的 JTable 对象。即刷新,上面的 post 解释得很好。

希望你做对了。