web-dev-qa-db-ja.com

PreparedStatementを使用して挿入します。 IDを自動インクリメントするにはどうすればよいですか?

次のようなPreparedStatementがあります。

 PreparedStatement preparedStatement = connect.prepareStatement("INSERT into employee (id, time, name" + "(?,?,?)",Statement.RETURN_GENERATED_KEYS);
 ResultSet tableKeys = preparedStatement.getGeneratedKeys();
 preparedStatement.executeUpdate();
 tableKeys.next();
 int autoGeneratedID = tableKeys.getInt(1);
 preparedStatement.setInt(1,autoGeneratedID);
 preparedStatement.setTimestamp(2, new Java.sql.Timestamp(new Java.util.Date().getTime()));                           
 preparedStatement.setString(3, "Test");
 preparedStatement.executeUpdate();

ご覧のとおり、Employeeテーブルには自動インクリメントされたIDがあります。基本的に、preparedStatementを使用して自動的に追加する必要があります。誰かが私がどこに間違っているのか教えてくれて、私を修正できますか?今のところ、Statementに関連するエラーが表示されます。

16
gran_profaci

INSERTステートメントから列を除外します全体。データベースエンジンによって生成されます。クエリは次のようになります。

INSERT INTO employee (time, name)
VALUES (?, ?)

次に、最初に挿入を実行してから、結果からキーを取得する必要があります。

私はあなたのコードは次のようになるべきだと信じています:

PreparedStatement preparedStatement = 
    connect.prepareStatement("INSERT into employee (time, name) VALUES (?,?)", 
    Statement.RETURN_GENERATED_KEYS);

preparedStatement.setTimestamp(1, 
    new Java.sql.Timestamp(new Java.util.Date().getTime()));                           
preparedStatement.setString(2, "Test");

preparedStatement.executeUpdate();

ResultSet tableKeys = preparedStatement.getGeneratedKeys();
tableKeys.next();
int autoGeneratedID = tableKeys.getInt(1);

この例では、実行されたステートメントの成功や返されたキーの存在はチェックされません。

28
lc.
    try{
        Class.forName("Oracle.jdbc.driver.OracleDriver");
        Connection con = DriverManager.getConnection("jdbc:Oracle:thin:@localhost:1521:xe","system","password");

        PreparedStatement ps = con.prepareStatement("insert into imgslider(id,cmnt,date1,img,status) values(seq.nextval,?,?,?,?)");
        ResultSet rs = null;

        String s1 = "I’ve Come and I’m Gone: A Tribute to Istanbul’s Street";
        ps.setString(1,s1);

        Calendar calendar = Calendar.getInstance();
        Java.sql.Date dd = new Java.sql.Date(calendar.getTime().getTime());
        ps.setDate(2,dd);

        FileInputStream f1 = new FileInputStream("F:\\Java\\slide-9.jpg");
        ps.setBinaryStream(3,f1,f1.available());

        ps.setInt(4,0);

        int i = ps.executeUpdate();
        System.out.println(i+" rows affected");

        con.close();
    }

これは、PreparedStatementによる表の自動インクリメント列のコードです。

0
Navit Antil