批量执行存储过程:不允许的操作: Stored procedure with out or inout parameters cannot be batched
if(parameters == null || parameters.size() <= 0) { return result; }
conn.setAutoCommit(false);
String sql = "call" + procedure + "(";
for (int i = 0; i < parameters.get(0).length; i++)
{
sql += "?,";
}
sql += "?)";
CallableStatement cs = conn.prepareCall(sql);
for (int i = 0; i < parameters.size(); i++)
{
this.prepareCommand(cs, parameters.get(i));
cs.registerOutParameter(parameters.get(i).length-1, oracle.jdbc.OracleTypes.NUMBER);
cs.addBatch();
}
cs.executeBatch();
conn.commit();
不允许的操作: Stored procedure with out or inout parameters cannot be batched
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
当初想执行的存储过程有输出参数,这句去掉就没办法获取输出参数了
去掉这句:
cs.registerOutParameter(parameters.get(i).length-1, oracle.jdbc.OracleTypes.NUMBER);