有没有办法使用 RETURNING INTO 获取受影响行的值?
我必须插入相同的行 x 次并获取插入行的 id。
该查询如下所示:
public static final String QUERY_FOR_SAVE =
"DECLARE " +
" resultId NUMBER ; " +
"BEGIN " +
" INSERT INTO x " +
" (a, b, c, d, e, f, g, h, i, j, k, l, m) " +
" values (sequence.nextVal, :a, :b, :c, :d, :e, :f, :g, :h, :i, :j, :k, :l) " +
" RETURNING a INTO :resultId;" +
"END;";
现在我可以使用 addBatch 在 JAVA 循环中将此查询添加到批处理中
IntStream.range(0, count)
.forEach(index -> {
try {
setting parameters...
cs.addBatch();
} catch (SQLException e) {
e.printStackTrace();
}
});
cs.executeBatch();
有什么方法可以像这样从批处理中返回数组或列表吗?
我可以仅使用 sql 执行这些插入 x 次,但在这种情况下,我还想知道如何返回 ids 数组。
提前致谢