我使用JDBC批量插入插入许多记录.
有没有办法获得每个记录生成的密钥?
可以使用ps.getGeneratedKeys()和批量插入吗?
有没有办法获得每个记录生成的密钥?
可以使用ps.getGeneratedKeys()和批量插入吗?
我正在使用oracle.jdbc.OracleDriver
final String insert = "Insert into Student(RollNumber,Name,Age) values(StudentSEQ.nextval,?,?)"; final int BATCH_SIZE = 998; int count = 0; Connection con = null; PreparedStatement ps = null; try { con = getConnection(); ps = con.prepareStatement(insert); for (Student s : students) { ps.setString(1,s.getName()); ps.setInt(2,s.getAge()); ps.addBatch(); count++; if (count % BATCH_SIZE == 0) { // Insert records in batches ps.executeBatch(); } } // Insert remaining records ps.executeBatch(); } finally { if(ps != null) ps.close(); release(con); }
我正在考虑在循环中使用ps.executeUpdate()以及ps.getGeneratedKeys()来获得所需的结果.任何其他解决方案?