我正在尝试从executeBatch()
事务中检索生成的密钥,但我只获得要添加的最后一个密钥。
这是我的代码:
PreparedStatement ps_insert = conn.prepareStatement(insertQuery, PreparedStatement.RETURN_GENERATED_KEYS);
for (int i = 0 ; i < adding_dates.length ; i++){
ps_insert.setInt(1, Integer.parseInt(consultant_id));
ps_insert.setDate(2, adding_dates[i]);
ps_insert.setInt(3, Integer.parseInt(room_id));
ps_insert.addBatch();
}
ps_insert.executeBatch();
ResultSet rs = ps_insert.getGeneratedKeys(); //<-- Only the last key retrieved
conn.commit();
我究竟做错了什么?
编辑:抱歉没有提到我在嵌入式模式下使用 H2 ( http://www.h2database.com/html/main.html ) 数据库。