0
我想運行一個SQL文件,它有很多插入狀態,並且我正在嘗試運行該文件,到目前爲止,我發現這個代碼,但它不是那麼好,因爲它給了我沒有找到表的錯誤,你可以看看代碼,也許你可以找到問題?使用嵌入式命令在Java中運行SQL文件
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
try {
URL = jTextField1.getText();
username = jTextField3.getText();
password = jTextField2.getText();
String s = new String();
StringBuilder sb = new StringBuilder();
Connection conn = (Connection) DriverManager.getConnection(URL, username, password);
Class.forName("com.mysql.jdbc.Driver");
try {
Statement st = conn.createStatement();
String query = "DELETE FROM player;";
st.executeUpdate(query);
JOptionPane.showMessageDialog(this, "Delete Compleated");
}catch (Exception e) {
JOptionPane.showMessageDialog(this, e.getMessage());
}
////////////////////////////////////////////////////////////////////////////////
try {
FileReader fr = new FileReader(new File("player.sql"));
// be sure to not have line starting with "--" or "/*" or any other non aplhabetical character
BufferedReader br = new BufferedReader(fr);
while ((s = br.readLine()) != null) {
sb.append(s);
}
br.close();
// here is our splitter ! We use ";" as a delimiter for each request
// then we are sure to have well formed statements
String[] inst = sb.toString().split(";");
Statement st = conn.createStatement();
for (int i = 0; i < inst.length; i++) {
// we ensure that there is no spaces before or after the request string
// in order to not execute empty statements
if (!inst[i].trim().equals("")) {
st.executeUpdate(inst[i]);
System.out.println(">>" + inst[i]);
}
}
JOptionPane.showMessageDialog(this,"Loaded Compleat");
} catch (Exception e) {
JOptionPane.showMessageDialog(this, e.getMessage());
}
DefaultTableModel model = (DefaultTableModel) jTable1.getModel();
try {
Statement st = conn.createStatement();
String query = "Select * from player;";
ResultSet rs = st.executeQuery(query);
while (rs.next()) {
int d1 = rs.getInt(1);
String d2 = rs.getString("PlayerName");
String d3 = rs.getString("PlayerSurname");
String d4 = rs.getString("PlayingPosition");
double d5 = rs.getDouble("PlayerRating");
model.addRow(new Object[]{
d1, d2, d3, d4, d5
});
}
rs.close();
st.close();
conn.close();
} catch (Exception e) {
JOptionPane.showMessageDialog(this, e.getMessage());
}
} catch (ClassNotFoundException ex) {
Logger.getLogger(Football.class.getName()).log(Level.SEVERE, null, ex);
} catch (SQLException ex) {
Logger.getLogger(Football.class.getName()).log(Level.SEVERE, null,ex);
}
}
THX任何幫助,您可以給:)我使用XAMPP和數據庫是所有準備創建了所有我需要的是填充它,
THX奏效:) THX很多 – 2011-12-20 10:42:18
確定之後追加的每一行,你就是歡迎 – 2011-12-20 10:45:18
你如何關閉這個問題? – 2011-12-20 10:46:56