java – 如何从JDBC中批量生成的密钥插入到Oracle中?

前端之家收集整理的这篇文章主要介绍了java – 如何从JDBC中批量生成的密钥插入到Oracle中?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用JDBC批量插入插入许多记录.
有没有办法获得每个记录生成的密钥?
可以使用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()来获得所需的结果.任何其他解决方案?

解决方法

看来Oracle 12c不支持按照以下页面自动生成的密钥与批量更新相结合:

http://docs.oracle.com/cd/E16655_01/java.121/e17657/jdbcvers.htm

请参阅“检索自动生成的密钥”一节中标有“限制”的小节.

猜你在找的Java相关文章