12

我正在使用 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()withps.getGeneratedKeys()来获得所需的结果。还有其他解决方案吗?

4

2 回答 2

7

JDBC 4.1 规范,第13.6 节检索自动生成的值说:

getGeneratedKeys调用executeBatch方法后是否返回生成的值是实现定义的。

因此,您需要检查您的驱动程序是否真的支持批量更新。如Philip O. 的回答所示, Oracle 12 JDBC Standards Support中记录的批量更新不支持检索生成的密钥:

您不能将自动生成的密钥与批量更新结合使用。

在任何情况下,如果您的驱动程序支持它,那么您的语句 prepare 应更改为以下代码以指示驱动程序检索生成的密钥:

ps = con.prepareStatement(insert, Statement.RETURN_GENERATED_KEYS);

注意:您可能需要使用其他生成的密钥准备方法之一(prepareStatement(sql, columnIndexes)prepareStatement(sql, columnNames)),因为 Oracle 将ROW_ID在我的示例中返回该方法。

于 2013-03-28T14:49:07.683 回答
3

根据以下页面,Oracle 12c 似乎不支持将自动生成的密钥与批量更新相结合:

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

请参阅“检索自动生成的密钥”部分下标有“限制”的小节

于 2013-08-07T16:20:15.513 回答