2017-04-03 25 views
0

私はjavaとDBMSを初めて使いました。私は、JTableを表示するために同じボタンをクリックしたときと、データベースにデータを書き込んだ後(書き込みボタンがクリックされたとき)、H2データベースに加えられた変更の後にJTableを更新/更新しようとしています。私はいくつかの方法を試して、いくつかの記事を読んだが、私のプログラムには欠かせない何かを見つけられなかった以下のコードは私の問題を示しています。JAVA:データベースを変更した後にテーブルを更新/更新する方法

これはデータベースから読み込まれ、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(); 
    } 
} 
+0

あなたの問題は何ですか、何かエラーがありましたか? –

答えて

0

にデータを書き込むために使用している方法であり、返信されましたhere

しかし、あなたのJTableオブジェクトをクリアして再レンダリングすることになります。リフレッシュすると、上のポストはそれを非常にうまく説明します。

あなたは正しいと思っています。

関連する問題