簡體   English   中英

如何從Oracle中的JDBC批量插入中獲取生成的密鑰?

[英]How to get generated keys from JDBC batch insert in 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()來獲得所需的結果。 還有其他方法嗎?

JDBC 4.1規范的第13.6節“ 檢索自動生成的值”說:

實現定義了getGeneratedKeys是否在調用executeBatch方法后返回生成的值。

因此,您需要檢查您的驅動程序是否實際支持批量更新。 正如Philip O.的回答所示, Oracle 12 JDBC標准支持中記錄的批量更新不支持檢索生成的密鑰:

您無法將自動生成的密鑰與批量更新組合在一起。

在任何情況下,如果您的驅動程序支持它,那么您的語句prepare應更改為以下代碼,以指示驅動程序檢索生成的密鑰:

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

注意:您可能需要使用其他生成的密鑰之一准備方法( prepareStatement(sql, columnIndexes)prepareStatement(sql, columnNames) ),因為Oracle將使用我的示例中的方法返回ROW_ID

根據以下頁面,Oracle 12c似乎不支持將自動生成的密鑰與批量更新相結合:

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

請參閱“檢索自動生成的密鑰”部分下標有“限制”的小節

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM