Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何从Oracle中的JDBC批插入中获取生成的密钥?_Java_Oracle_Jdbc_Primary Key_Batch Insert - Fatal编程技术网

Java 如何从Oracle中的JDBC批插入中获取生成的密钥?

Java 如何从Oracle中的JDBC批插入中获取生成的密钥?,java,oracle,jdbc,primary-key,batch-insert,Java,Oracle,Jdbc,Primary Key,Batch Insert,我正在使用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; C

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

第13.6节检索自动生成的值时说:

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

因此,您需要检查您的驱动程序是否支持批量更新。如中所述,批量更新不支持检索生成的密钥,如中所述:

不能将自动生成的密钥与批更新相结合

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

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

注意:您可能需要使用其他生成的密钥准备方法之一(或),因为Oracle将使用我的示例中的方法返回
行ID

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


请参阅“检索自动生成的键”一节下标记为“限制”的小节。

在批插入中是否使用序列?是的,StudentSEQ是表格的序列。