使用游标显示销售报表_游标- FineReport帮助文档 - 全面的报表使用教程和学习资料...

如:在 Oracle 数据库中,会报如下信息:

Caused by: ORA-01000: 超出打开游标的最大数

Oracle 系统中,以参数 open_cursors 来限制打开的游标数,当打开游标超过这个数的时候就会报这个错,提示超出打开游标的最大数。游标个数理论上没有上限,也不是越大越好。

有这样一个测试显示:当这个 open_cursor 数值大了一定程度之后,会使得内存缩水,缩水的表现就是连接数减少。

如上结论可具体测试,其测试结果如下:

分别设置为以下值,测试数据库的连接,在同样的内存配置下,与用户可以连接的数(独占模式)有很大的区别。

open_cursors=6000000000 -------------连接数 45

open_cursors=300 ---------------------连接数超过 500.

由以上测试可知,当 open_cursors 扩大 2000 万倍之后连接数变为原来的十分之一,因此 open_cursors 的大小对连接数的影响不大,只要不要在千万级上增加,一般的几千几万跟几十,对连接数的影响甚微。

4.1 解决方案

按照游标的正规写法,打开游标使用完之后,就需关闭游标。

应避免游标打开过大,其可通过修改 open_cursors 大小,使其尽可能大。

4.2 检查 open_cursors 数值及修改方法

SQL>show parameter open_cursors; ---显示参数值

SQL>alter system set open_cursors = 1000; ---修改参数值为1000

SQL>commit;----提交

修改成功。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值