超出打开游标最大数、ORA-01000: 超出打开游标的最大数
上面章节,我们对游标的内容有了些详细的了解。但在使用游标时,往往会出现些问题。下面就打开的游标太多时,出现的一些问题作介绍。
1. 报错信息
如:在Oracle数据库中,会报如下信息:
Caused by: ORA-01000: 超出打开游标的最大数
Oracle系统中,以参数open_cursors来限制打开的游标数,当打开游标超过这个数的时候就会报这个错,提示超出打开游标的最大数。游标个数理论上没有上限,也不是越大越好。
有这样一个测试显示:当这个open_cursor数值大了一定程度之后,会使得内存缩水,缩水的表现就是连接数减少。
如上结论可具体测试,其测试结果如下:
分别设置为以下值,测试数据库的连接,在同样的内存配置下,与用户可以连接的数(独占模式)有很大的区别。
open_cursors=6000000000 -------------连接数45
open_cursors=300 ---------------------连接数超过500.
由以上测试可知,当open_cursors扩大2000万倍之后连接数变为原来的十分之一,因此open_cursors的大小对连接数的影响不大,只要不要在千万级上增加,一般的几千几万跟几十,对连接数的影响甚微。
2. 解决方案
按照游标的正规写法,打开游标使用完之后,就需关闭游标。
应避免游标打开过大,其可通过修改open_cursors大小,使其尽可能大。
2.1 检查open_cursors数值及修改方法
SQL>show parameter open_cursors; ---显示参数值
SQL>alter system set open_cursors = 1000; ---修改参数值为1000
SQL>commit;----提交
修改成功。
返回顶部