java.sql.SQLException: ORA-01000: 超出打开游标的最大数
问题在一个大数据量的嵌套循环下 close() 关闭 createStatement() 根本无效,即使把执行过程封装在类里,而用循环来调用类也会有问题。
原因:
close() 后游标里缓存的资源并不会被释放,而是返回给数据库连接池,直到退出最外层的循环,才会自动被释放。
解决方案:
方案一: 如果数据库不是超级大,一般通过直接在数据库里调大 open_cursors 游标参数可解决问题。
方案二: 超大数据量的话,要拆分大量数据为小量的数据,把循环放在类里进行封装,最后把结果拼起来就好了。
show parameter open_cursors;
可以查看游标的最大值。
alter system set open_cursors=5000 scope=both;
可以设置游标的最大值。
喜欢的点个赞❤吧!