Java 技术篇 - 连接oracle数据库执行sql使用close()关闭createStatement()无效无法清除游标缓存问题解决,报“ORA-01000: 超出打开游标的最大数“错误解决方法
生活随笔
收集整理的这篇文章主要介绍了
Java 技术篇 - 连接oracle数据库执行sql使用close()关闭createStatement()无效无法清除游标缓存问题解决,报“ORA-01000: 超出打开游标的最大数“错误解决方法
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
java.sql.SQLException: ORA-01000: 超出打开游标的最大数 问题在一个大数据量的嵌套循环下 close() 关闭 createStatement() 根本无效,即使把执行过程封装在类里,而用循环来调用类也会有问题。
原因:
close() 后游标里缓存的资源并不会被释放,而是返回给数据库连接池,直到退出最外层的循环,才会自动被释放。
解决方案:
方案一: 如果数据库不是超级大,一般通过直接在数据库里调大 open_cursors 游标参数可解决问题。
方案二: 超大数据量的话,要拆分大量数据为小量的数据,把循环放在类里进行封装,最后把结果拼起来就好了。
show parameter open_cursors; 可以查看游标的最大值。
alter system set open_cursors=5000 scope=both; 可以设置游标的最大值。
喜欢的点个赞❤吧!
总结
以上是生活随笔为你收集整理的Java 技术篇 - 连接oracle数据库执行sql使用close()关闭createStatement()无效无法清除游标缓存问题解决,报“ORA-01000: 超出打开游标的最大数“错误解决方法的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: PyQt5 图形界面 - Qt Desi
- 下一篇: Java 技术篇 - 从指定的web网页