JDBC execute()方法执行存储过程超时不返回值怎么办?
发现我项目的JDBC CallableStatement.execute()方法执行存储过程时如果时间超过一个多小时就不会返回值了,请问各位大神有办法避免这个情况么?如果可以延长超时时间是最好的,谢谢!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发现我项目的JDBC CallableStatement.execute()方法执行存储过程时如果时间超过一个多小时就不会返回值了,请问各位大神有办法避免这个情况么?如果可以延长超时时间是最好的,谢谢!
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(6)
CommandTimeout 这个值在那里改啊?我用的是webSphere容器
确实是楼上说的这样,我也遇到同样的问题
我现在试一下在容器webSphere里面改几个JDBC的参数看行不行吧。
回复
请问这个CommandTimeout 怎么设置呢?我还找不到在哪里设。谢谢!
回复
@藤真 : 如果你的存储过程执行过长可以将值设置的大一些
1、 java调用存储过程中的 CommandTimeout 默认值是30秒,当你的存储过程执行超过这个时间的时候就会报错。可以考虑CommandTimeout的值设置大一些CommandTimeout=3000
2、测试你的存储过程 如果执行时间过长 或者是根本不出结果。肯定应该优化你的sql存储过程,如果可以试着将你的存储过程分为多个执行。