1

メンバーを編集する方法があり、エラーをファイルに出力したいのですが、スタック トレースを Error_Report.txt ファイルに出力しようとすると、void cannot be dereferenced エラーが発生し続けます。とにかく私はそれを印刷することができますか?これは私のコードです。

public void edit() {
  FileWriter fw = new FileWriter(new File("Error_Report.txt"));
  Connection con;
  Statement stmt;
  ResultSet rs;

  int id = (int)_id.getSelectedItem();
  String name = _name.getText();
  String user = _username.getText();
  String pass = _password.getText();
  String pos = _position.getSelectedItem().toString();

  try {
    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    con = DriverManager.getConnection("jdbc:odbc:collegesys", 
                                      "root", "0blivi0n");

    stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
                               ResultSet.CONCUR_READ_ONLY);

    PreparedStatement prep = con.prepareStatement("UPDATE `main` WHERE ID = ?");
    prep.setInt(1, id);
    prep.setString(2, name);
    prep.setString(3, user);
    prep.setString(4, pass);
    prep.setString(5, pos);

    prep.execute();
  } catch(SQLException sqle) {
    String sql = sqle.printStackTrace().toString();
    fw.write("" + sql);
  } catch(ClassNotFoundException cnfe) {
    fw.write("" + cnfe);
  }
}
4

2 に答える 2

5

あなたの問題は、printStackTrace何も返さないため、文字列に変換するものがないことです。このように書きます。

PrintWriter writer = new PrintWriter(fw);
sqle.printStackTrace(writer);
writer.close();
于 2012-05-26T04:25:41.803 に答える
4

sqle.printStackTrace()void を返し、パラメーターとして使用できません。コードを次のように変更します。

catch(SQLException sqle) {
    StringBuilder sb = new StringBuilder();
    StackTraceElement[] st = sqle.getStackTrace();
    for(StackTraceElement s : st) {
        sb.append(s);
        sb.append('\n');
    }
    fw.write(sb.toString());
} 
于 2012-05-26T04:23:07.300 に答える