批量执行存储过程:不允许的操作: Stored procedure with out or inout parameters cannot be batched

发布于 2021-11-19 15:04:07 字数 1932 浏览 760 评论 2

 

 

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

梦里兽 2021-11-20 07:43:11

当初想执行的存储过程有输出参数,这句去掉就没办法获取输出参数了

酷到爆炸 2021-11-20 07:12:36

去掉这句:
 cs.registerOutParameter(parameters.get(i).length-1,  oracle.jdbc.OracleTypes.NUMBER);

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文