Welcome 微信登录

首页 / 数据库 / MySQL / 错误 ORA-01000: maximum open cursors exceeded Exception

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         xxxKUL-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) { }
 
}相关阅读:关于ORA-01000: maximum open cursors exceeded" 问题分析总结 http://www.linuxidc.com/Linux/2013-06/86057.htm关于Oracle游标的问题(ORA-01000: maximum open cursors exceeded)  http://www.linuxidc.com/Linux/2009-01/18148.htmOracle ORA-01000:maximum open cursors exceeded  http://www.linuxidc.com/Linux/2013-01/77754.htmORA-01000: maximum open cursors exceeded  http://www.linuxidc.com/Linux/2013-02/80071.htm更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12Oracle启用自动归档模式安装完 MySQL 后必须调整的 10 项配置相关资讯      ORA-01000 
  • ORA-01000 解决方法  (10/14/2015 19:31:45)
  • ORA-01000: maximum open cursors   (02/27/2013 09:35:11)
  • 关于ORA-01000: maximum open   (06/15/2013 11:47:06)
  • Oracle ORA-01000:maximum open   (01/13/2013 14:26:22)
本文评论 查看全部评论 (0)
表情: 姓名: 字数