JDBC execute()方法执行存储过程超时不返回值怎么办?

藤真 发布于 2018/08/02 18:09
阅读 775
收藏 0

发现我项目的JDBC CallableStatement.execute()方法执行存储过程时如果时间超过一个多小时就不会返回值了,请问各位大神有办法避免这个情况么?如果可以延长超时时间是最好的,谢谢!

加载中
0
melon_jj
melon_jj

1、  java调用存储过程中的 CommandTimeout 默认值是30秒,当你的存储过程执行超过这个时间的时候就会报错。可以考虑CommandTimeout的值设置大一些CommandTimeout=3000

 

2、测试你的存储过程 如果执行时间过长 或者是根本不出结果。肯定应该优化你的sql存储过程,如果可以试着将你的存储过程分为多个执行。

melon_jj
melon_jj
回复 @藤真 : 如果你的存储过程执行过长可以将值设置的大一些
melon_jj
melon_jj
回复 @藤真 可以直接Q我3474203856 详细交流一下,这样不能及时看到比较麻烦。
藤真
藤真
回复 @melon_jj : 请问这个CommandTimeout 怎么设置呢?我还找不到在哪里设。谢谢!
melon_jj
melon_jj
回复 @藤真 : 你好,请问还有其它问题吗?如果我的回答你满意,请点击采纳,谢谢。也可加我QQ一起讨论:3474203856
藤真
藤真
我现在试一下在容器webSphere里面改几个JDBC的参数看行不行吧。
0
杨帆yf

确实是楼上说的这样,我也遇到同样的问题

藤真
藤真
CommandTimeout 这个值在那里改啊?我用的是webSphere容器
0
Choco_men
Choco_men

是的,如楼上所说,可以从存储过程本身找问题

返回顶部
顶部