hibernate3.2打开游标过多:出现ORA-01000: maximum open cursors exceeded错误

本文探讨了在使用Hibernate连接Oracle数据库时遇到的ORA-01000错误(游标超过最大限制)。分析了问题的原因在于Statement未正确关闭,并提出了两种解决方案:一是禁用PreparedStatement缓存;二是调整Oracle的最大游标数设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    系统采用系统采用hibernate 3.2.0连接Oracle 10g:

 

    dao类中获取hibernate session的方式,都是通过ThreadLocal来的,并且确认会在数据库操作完成之后,在finally中执行Session.close()。 但是运行时间长了以后,出现ORA-01000: maximum open cursors exceeded

 

    网上翻看了一些资料,基本得出结论:jdbc规范中要求connection在close的时候自动close它所产生的 statement和result set,但是容器的数据源中的connection,因为被容器托管了,所以在close的时候,并不会按照jdbc的规范去做,它只是回到连接池,而不 是真正关闭。所以执行Session.close后,但是Statement没有被同时关闭,而且因为仍然被应用也不会被gc,长时间运行就会造成游标过 大。

 

解决的途径:

  途径一:

在hibernate.org的一个faq上看到了这一条:

Q:After a while, Oracle throws this exception: too many open cursors

A:The Oracle JDBC driver doesn't much like to have its prepared statements cached. Disable PreparedStatement caching for the connection pool.

 

   途径二:

增大游标最大值,据说是不影响性能,有待考验,Oracle默认游标最大值是300,如果想增加最大值可以用如下方法:

sqlplus /nolog

SQL>conn /as sysdba

SQL>show parameter open_cursors;

SQL>alter system set open_cursors=1500 scope=both;

退出重启oracle服务即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值