当前位置:  数据库>oracle

错误 ORA-01000: maximum open cursors exceeded Exception

    来源: 互联网  发布时间:2017-05-31

    本文导语: ORA-01000是开发中常见的异常。这个异常表示程序中打开的游标数目> 数据库中设定的可以打开的最大游标数。 这个异常通常由2个原因导致 1. 数据库中设置的maximum open cursors太小 2. 在 Java JDBC程序中通常是代码中打开的ResultSet ...

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" 问题分析总结

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

Oracle ORA-01000:maximum open cursors exceeded 

ORA-01000: maximum open cursors exceeded 


    
 
 

您可能感兴趣的文章:

  • 我用javac编译HelloWorldapp.java无错误,但运行时出现该错误:Exception in thread "main" java.lang.NoClassDefFoundError: helloworldapp
  • 这个错误是什么原因Exception in thread "main" java.lang.NoClassDefFoundError:
  • 初级问题:为什么出现Exception in thread "main" java.lang.NoClassDefFoundError错误?
  • 这个错误是因为什么?Exception in thread "main" java.lang.NoClassDefFoundError:Example
  • 我在测试我.class文件时总提示这样的错误:Exception in thread "main" java.lang.noclassdefoundError:myclass
  • java程序运行时错误Exception in thread "main" java.lang.NoClassDefFoundError: myjava
  • Exception in thread "main" java.lang.NoClassDefFoundError是什么错误?
  • 请问我在编译JAVA程序时,为何总是出现Exception in thread "main" java.lang.NoClassDefFoundError的错误
  • 出现了错误:java.lang.NoClassDefFoundError: com/inprise/ejb/Container;和Exception in thread "main"
  • 最简单的helloworld程序怎么出现Exception in thread "main" java.lang.NoClassDefFoundError: sunhello错误?
  • exception in thread "main" java.lang.NoClassDeffoundError:FindMax/class出现这种错误提示,我错在哪呢?
  • 我安装完j2sdk1.4.1后,设置完path和classpath后,测试java app 提示错误:Exception in thread "main" java.lang.NoclassDefFoundError:
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • C++ I/O 成员 bad():如果出现错误则返回true
  • Unmounting initrd failed 错误表示什么错误?可能是由什么引起的?系统原来一直运行正常,突然发现系统登陆错误,重启提示以上错误。
  • C++ I/O 成员 fail():如果出现错误则返回true
  • 在inter版solaris 8上编socket程序,在read时遇到错误,错误号14,用strerror()看不到错误描述,请解决,多谢!
  • 重装服务器后IIS网站错误(应用程序中的服务器错误)
  • 请问段错误是什么错误啊
  • Mysql查询错误:ERROR:no query specified原因
  • linux安装codeblock 编译错误make: *** [all-recursive] 错误 1
  • windows server2008上PowerBuilder程序系统错误解决方法
  • 求教:文件打包移植错误发生排序错误,小弟努力送分送分啦!59~~~
  • 错误:将'const x'作为'x'的'this'实参时丢弃了类型限定问题解决
  • 解决服务器应用程序不可用,错误:0x80070005拒绝访问的错误
  • 几个windows平台C++开发错误举例
  • iis8.5显示ASP的详细错误信息500 内部服务器错误解决方法
  • 安装hadoop时出现内存不够及其它一些常见的hadoop错误解决办法
  • http错误404-文件或目录未找到 错误的解决方法
  • PHP严重致命错误处理:php Fatal error: Cannot redeclare class or function
  • mysql启动错误之mysql启动报1067错误解决方法
  • linux/centos安装nginx常见错误及解决办法
  • gnu c++如何得到对于编译错误和运行错误的帮助?
  • 紧急求救:在LINUX下如何根据错误代码,查出对应的错误描述?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,