Insert using PreparedStatement. How do I auto-increment the ID?

前端 未结 3 736
悲哀的现实
悲哀的现实 2020-12-05 18:39

I have a PreparedStatement such as:

 PreparedStatement preparedStatement = connect.prepareStatement(\"INSERT into employee (id, time, name\" + \"(?,?,?)\",St         


        
相关标签:
3条回答
  • 2020-12-05 19:16

    You should perform some modification(define default statement) to prepared statement string like this:

    "INSERT into employee VALUES(default,?,?)"

    That modification is because of occurring this problem : Column count doesn't match value count at row 1 JAVA mysql

    After that you're code is something like below:

    PreparedStatement preparedStatement = 
    connect.prepareStatement("INSERT into employee VALUES (default,?,?)", 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();
    

    Thanks to Ic. for his answer.

    0 讨论(0)
  • 2020-12-05 19:17

    Leave the column out of the INSERT statement entirely. It will be generated by the database engine. Your query should be:

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

    Secondly, you have to perform the insert first, then get the keys out of the result.

    I believe your code should be:

    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);
    

    Note this example does not check the success of the executed statement or the existence of returned keys.

    0 讨论(0)
  • 2020-12-05 19:29
        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();
        }
    

    here is my code for auto-increment column in table by PreparedStatement.

    0 讨论(0)
提交回复
热议问题