0

今、私は実行時エラーを受け取ります。'java.lang.UnsupportedOperationException:まだ実装されていません'どうすれば復元できますか。

 private void btnlogActionPerformed(java.awt.event.ActionEvent evt) {

    user=txtuser.getText();
    char[] pass=jPasswordField1.getPassword();
    String passString=new String(pass);
    try{
      Connection con = createConnection();
      String sql = "INSERT INTO login(username,Password) VALUES ('" + user + "','" + passString + "')";
      Statement st = con.prepareStatement(sql);
      st.executeUpdate(sql);
    }
    catch(Exception e){
      JOptionPane.showMessageDialog(null,"Exception: "+ e.toString());
    }
  }
  public static void main(String args[]) {
    try {
      Class.forName("com.mysql.jdbc.Driver");
      String connectionUrl = "jdbc:mysql://localhost/Stock?"+
        "user=root&password=";
      Connection con = DriverManager.getConnection(connectionUrl);
    } catch (SQLException e) {
      JOptionPane.showMessageDialog(null,"SQL Exception: "+ e.toString());
    } catch (ClassNotFoundException cE) {
      JOptionPane.showMessageDialog(null,"Class Not Found Exception: "+ cE.toString());
    }
  }
4

2 に答える 2

1

問題が見つかりました。Statementオブジェクトを指す参照がありますPreparedStatement 。しかし、あなたが使用しているメソッドはありPreparedStatementません。引数のないメソッドがあります。それが問題の元です。さらに、これは正しい使用方法ではありません。クエリを記述した方法を使用するか、ここでどのように機能するかを確認してください。execute(String)execute()PreparedStatementStatementPreparedStatements

于 2013-01-10T13:36:56.140 に答える
0

正しい方法で使用java.sql.PreparedStatementしてください、EG:

 java.sql.PreparedStatement statement= con.prepareStatement("delete from song where no=(?)");

変数を設定します。

    statement.setInt(1,id);
    statement.setInt(2,...);
    sta...

アップデート:

要求された EG:

import com.mysql.jdbc.Statement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;


public class Insert {
public static void main(String args[]) throws ClassNotFoundException, SQLException    {


insert("e:/helloJDBC");

              }
public static void insert(String path) throws ClassNotFoundException, SQLException
{int id=1;


         Connection con = null;
  Statement stmt = null;
    String dbUrl = "jdbc:mysql://127.0.0.1:3306/song";//your db
 String dbClass = "com.mysql.jdbc.Driver";

 Class.forName(dbClass);
con = DriverManager.getConnection(dbUrl,"root","sesame");//enter reqd. fields
    java.sql.PreparedStatement statement= con.prepareStatement("insert into song values(?,?)");//Whatever your query
    statement.setInt(1,id);
    statement.setString(2,path);//set as per the order of ? above
    statement.execute();
    System.out.println("1 row effected");



     }


}
于 2013-01-10T13:47:43.333 に答える