分享

BlogJava - 天道酬勤 - 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)

 加菲 2006-04-04

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

昨天在开发过程中,经常碰到ORA-01000: maximum open cursors exceeded这个错误。一看报错,知道是游标超过最大数了,以前在做DB2开发的时候,也曾遇到过类似的问题。虽然解决了,但一直没弄清楚,JDBC是如何和数据库发生交互的?又是在什么时候打开数据库游标的?脑袋就跟浆糊一样,说来真是惭愧啊

昨天google了一把,终于解开一点迷惑了。

下面的片断转载于www.

[TIP]关于Java开发中使用Oracle数据库的一点注意事项(原创)

很多朋友在Java开发中,使用Oracle数据库的时候,经常会碰到有ORA-01000: maximum open cursors exceeded.的错误。

实际上,这个错误的原因,主要还是代码问题引起的。
ora-01000: maximum open cursors exceeded.
表示已经达到一个进程打开的最大游标数。

这样的错误很容易出现在Java代码中的主要原因是:Java代码在执行conn.createStatement()和conn.prepareStatement()的时候,实际上都是相当与在数据库中打开了一个cursor。尤其是,如果你的createStatement和prepareStatement是在一个循环里面的话,就会非常容易出现这个问题。因为游标一直在不停的打开,而且没有关闭。

一般来说,我们在写Java代码的时候,createStatement和prepareStatement都应该要放在循环外面,而且使用了这些Statment后,及时关闭。最好是在执行了一次executeQuery、executeUpdate等之后,如果不需要使用结果集(ResultSet)的数据,就马上将Statment关闭。

对于出现ORA-01000错误这种情况,单纯的加大open_cursors并不是好办法,那只是治标不治本。实际上,代码中的隐患并没有解除。
而且,绝大部分情况下,open_cursors只需要设置一个比较小的值,就足够使用了,除非有非常特别的要求。

我昨天犯的错误就是把创建statement放到了循环之内,结果导致cursor猛增,到达了数据库设置的最大数。
虽然解决了问题,也清楚了游标是何时创建的,但还有几个问题比较迷糊。
1、通过查询,JDBC是将所有的查询结果一次性放到ResultSet中,还是一次只放一定数目的记录?例如,查询结果为2000条数据,JDBC是一次性将2000条数据放到结果集中,还是分批放置呢?

2、当通过ResultSet.next(),移动结果集指针时,此时是否还与数据库发生交互?

posted on 2005-01-27 10:15 候鸟南飞 阅读(4092) 评论(9)  编辑 收藏 收藏至365Key

评论

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

连接和statement使用完毕之后应该及时关闭,这个应该是粉简单的道理吧.
2005-01-27 10:53 | eamoi

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

鸟人
还没回到阿?
2005-02-17 21:33 | 不至于

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   


2005-03-29 15:05 |

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

The article is great. I got the same error and keep scratching my head till I found your page. Keep it up!
2005-04-28 15:39 | San

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

继续下去啊。这个问题应该是一个比较典型的问题了吧,继续讨论阿
2005-05-10 18:27 | 芨芨草

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

pst.close();
rs.close();

只要及时关闭应该就可以了吧?
2005-07-05 15:23 | plutohades

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

首先结果集resultset在你的java程序处。其中有个fetchsize设置,这个表示每次从数据库处取多少条记录到resultset.
2006-03-14 09:42 |

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

当通过ResultSet.next(),移动结果集指针时,此时是否还与数据库发生交互?

不发生交互,数据库执行完查询后,已经把查询结果交给ResultSet了,以后的操作,和数据库无关。
2006-03-15 10:26 | jing

# re: 关于ORACLE游标的问题(ORA-01000: maximum open cursors exceeded)  回复   

交互,如果1个查询有10000条记录,resultset中只有fetchsize条,当next时还会在一定时机去交互
2006-03-17 10:44 |

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多