错误 ORA-01000: maximum open cursors exceeded Exception

php中文网
发布: 2016-06-07 17:34:56
原创
2746人浏览过

ORA-01000是开发中常见的异常。这个异常表示程序中打开的游标数目gt; 数据库中设定的可以打开的最大游标数。

ora-01000是开发中常见的异常。这个异常表示程序中打开的游标数目> 数据库中设定的可以打开的最大游标数。
 
这个异常通常由2个原因导致
 
1. 数据库中设置的maximum open cursors太小
 
2. 在 java jdbc程序中通常是代码中打开的resultset 或 preparedstatment 没有被关闭。 
 
什么是游标
 
游标就是看成是指向结果集的指针。可以把它看成一种资源,或者一种数据结构。 
 
 
查看系统中允许的最大游标数和 历史上打开的最大游标数
 
select max(a.value) as highest_open_cur, p.value as max_open_cur
from v$sesstat a, v$statname b, v$parameter p
where a.statistic# = b.statistic# and b.name = 'opened cursors current'  and p.name= 'open_cursors'
group by p.value;
 

HIGHEST_OPEN_CUR      MAX_OPEN_CUR
 
----------------      ------------
 
69                    300
 
 
从结果可以看出,,系统允许的最大游标数是300,  历史上最大打开游标数是30, 可以得出结论300 够用了。如果两个数字很接近或相等,那么就要修改最大允许游标数了。 
 
查看时谁在适用游标


select sum(a.value) total_cur, avg(a.value) avg_cur,
 
max(a.value) max_cur, s.username, s.machine
 
from v$sesstat a, v$statname b, v$session s
 
where a.statistic# = b.statistic# and s.sid=a.sid
 
and b.name = 'opened cursors current'
 
group by s.username, s.machine order by 1 desc
 
 
 

TOTAL_CUR  AVG_CUR    MAX_CUR    USERNAME    MACHINE
 
---------  -------    -------    --------    -------
 
114        14.25      69          A          KUL-0121
 
76          8.44        48          B          KUL-0121
 
29          1.38        18                      KUL-0121
 26          8.67        13          C          xxx\KUL-012 
 
 
 
既然我们已经可以从系统中知道游标的适用情况,那么下面就要fix 这个异常。
 
1. 通过设置OPEN_CURSORS, MAX_VALUE增加最大游标数

ALTER SYSTEM SET OPEN_CURSORS = MAX_VALUE SID='*' SCOPE=BOTH; 
 
 
2. 通常这个异常是由Java程序未关闭ResultSet 或者 PreparedStatment 造成的。正确的适用方法, 总是把close()放在finally中,这样不管有没有发生其他异常,都会关闭ResultSet 和 PreparedStatement. 


Statement stmt = conn.createStatement();
 
try {
 
    ResultSet rs = stmt.executeQuery( "SELECT FULL_NAME FROM EMP" );
 
    try {
 
        while ( rs.next() ) {
 
            System.out.println( "Name: " + rs.getString("FULL_NAME") );
 
        }
 
    } finally {
 
        try { rs.close(); } catch (Exception ignore) { }
 
    }
 
} finally {
 
    try { stmt.close(); } catch (Exception ignore) { }
 
}

相关阅读:

SuperDesign
SuperDesign

开源的UI设计AI智能体

SuperDesign 216
查看详情 SuperDesign

关于ORA-01000: maximum open cursors exceeded" 问题分析总结

关于Oracle游标的问题(ORA-01000: maximum open cursors exceeded) 

Oracle ORA-01000:maximum open cursors exceeded 

ORA-01000: maximum open cursors exceeded 

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号