很多朋友在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只需要设置一个比较小的值,就足够使用了,除非有非常特别的要求。
---
如果你不使用连接池,那么就没有什么问题,一旦Connection关闭,数据库物理连接就被释放,所有相关Java资源也可以被GC回收了。
但是如果你使用连接池,那么请注意,Connection关闭并不是物理关闭,只是归还连接池,所以PreparedStatement和ResultSet都被持有,并且实际占用相关的数据库的游标资源,在这种情况下,只要长期运行,往往就会报“游标超出数据库允许的最大值”的错误,导致程序无法正常访问数据库。
---
这个关不关和使用不使用conn pool没有关系,一般操作是会是这样,线程从外界获取一个conn,然后创建自己地stmt,rs,然后执行逻辑操作,然后将conn返回给pool。 如果程序员忘记手动关地话。当这个线程执行完以后,stmt,rs都成垃圾,当他们被垃圾搜集地时候,gc会替我们把它们给关闭地。这就是很多代码没有关闭,仍然正常运行。
但是这样会有一个潜在地问题。就是gc无法确定什么时候运行。如果free地内存很多,很可能有些gc就不会被启动,这样stmt迟迟没有被关闭,执行一段时间会报错。
所以健壮地代码应该手工把rs,stmt都关闭
---
Java连结Oracle常犯错误
1。只懂 createStatement,不懂关闭statement
2.。只懂 createStatement,不懂preparedStatement.
3 。只懂在sql里用to_date,甚至直接用String,不懂用 setDate()
---
我记得.我的程序中也出现过这种问题,
主要原因是我get Connection 对象后,这个connectin没有被进行关闭,
同时进行出来的 preparedStatement 对象,不关闭也会出现这种问题,
而且,推荐这些数据库操作的变量尽量用局部变量,现用现取,随时关闭,而且放在finally{}中进行关闭,比较保险
---
通常這樣的情形是你使用了超過DB設定同時可用的connection數量
你可以試試看下列方式:
1. 若你使用connection pool, 你可以將connection pool的max connection
數量降低看看, 同時檢查有無歸還connection
2. 若未使用conneciton pool, 你就該檢查一下, 你的connection在使用過後
有沒有關閉囉
另外一種情形是: 你的系統使用量真的很大, 所以同時150的DB connection
session是不夠的, 你就需要調整Oracle DB囉
分享到:
相关推荐
这篇博客的下篇主要讨论了如何在关闭Connection时自动关闭Statement和ResultSet,以确保资源的有效释放,防止内存泄漏。以下是对这个主题的详细解释。 首先,我们需要理解数据库连接、Statement和ResultSet在JDBC中...
在使用JDBC和PrepareStatement时,别忘了关闭资源,例如ResultSet、Statement和Connection,以避免内存泄漏。可以使用try-with-resources语句来确保资源的正确关闭。 这个资源提供的示例代码将帮助开发者深入理解...
##### 1.2.2 关闭Statement ```java public static void close(Statement stmt) { if (null != stmt) { try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 与关闭`Connection`...
3. **关闭资源**:使用完ResultSet后,记得关闭它,以及对应的Statement和Connection,以释放数据库资源。通常在finally块中使用close()方法。 4. **事务管理**:在处理ResultSet时,应考虑事务的边界。确保在开始...
在Java中,我们可以使用try-with-resources语句,它会自动关闭在try块中声明的实现了AutoCloseable接口的对象,例如Connection、Statement和ResultSet。 下面是一个示例,展示了如何正确关闭数据库连接: ```java ...
本文将基于给定的信息——“数据库连接方法包括连接和关闭资源”,深入探讨SQL数据库连接的相关知识点,涵盖连接方法、资源管理及重载方法等方面。 ### 数据库连接:基本概念 数据库连接是应用程序与数据库之间...
在实际开发中,为了提高性能和防止SQL注入,通常会使用`PreparedStatement`而不是`Statement`,并且推荐使用数据库连接池来管理数据库连接。数据库连接池如HikariCP、C3P0或Apache DBCP等,能有效提升应用程序的效率...
Statement接口用于执行静态SQL语句,例如查询、插入、更新和删除数据。你可以通过`Connection.createStatement()`方法创建Statement实例,然后调用`executeQuery()`或`executeUpdate()`方法来执行SQL语句。 ```java...
5. **关闭资源:** 最后记得关闭 `ResultSet`、`Statement` 和 `Connection` 对象。 **示例代码:** ```jsp ;charset=gb2312" %> *" %> String result = ""; // 存储查询结果 String sql = "SELECT * FROM test...
记住使用完后要关闭`ResultSet`、`Statement`和`Connection`,以释放数据库资源: ```java rs.close(); stmt.close(); conn.close(); ``` 9. **预编译的PreparedStatement** `PreparedStatement`是`...
在处理完查询结果后,记得关闭所有打开的资源,包括ResultSet、Statement和Connection,以避免资源泄漏。 ```java rs.close(); stmt.close(); con.close(); ``` 总结起来,使用JDBC在JSP中访问SQL Server数据库的...
在Java编程中,连接MySQL数据库是一项基础且重要的任务。它涉及到Java Database Connectivity (JDBC) API的使用,这个API允许Java...同时,为了提高性能和防止SQL注入,推荐使用`PreparedStatement`代替`Statement`。
1. Statement 和 PreparedStatement 之间的区别:Statement 接口用于执行静态 SQL 语句,而 PreparedStatement 接口用于执行动态 SQL 语句,可以重复使用该语句。 2. 进行数据库连接、操作的主要步骤:加载驱动程序...
顺序是先关闭`ResultSet`,然后关闭`Statement`,最后关闭`Connection`: ``` rs.close(); statement.close(); con.close(); ``` 在上述示例代码中,`Test01`类展示了这些步骤的完整实现。运行这个类会从名为`...
// 关闭Statement conn.close(); // 关闭连接 %> ``` ##### 3. 解析 - `Class.forName()`用于加载Oracle的JDBC驱动。 - `DriverManager.getConnection()`方法建立数据库连接。 - 使用`Statement`执行SQL语句。...
// 关闭Statement conn.close(); // 关闭数据库连接 ``` 以上是JDBC连接数据库的基本步骤,但实际开发中,为了提高代码的可读性和安全性,通常会使用`PreparedStatement`代替`Statement`,以防止SQL注入攻击。...
在Java数据库连接(JDBC)中,连接...总结来说,JDBC连接数据库涉及加载驱动、建立连接、创建Statement、执行SQL和处理结果集等步骤,同时要注意异常处理和资源的正确关闭,以保证程序的健壮性和数据库资源的有效利用。
- 关闭资源:确保在操作完成后,按顺序关闭ResultSet、Statement和Connection。 3. **JDBC工具类的关键方法** - `getConnection()`: 这个方法通常会使用数据库URL、用户名和密码创建连接。为了提高性能,它可能还...
6. 关闭资源:确保在操作完成后关闭Statement、ResultSet和Connection,释放系统资源。 ```java stmt.close(); rs.close(); conn.close(); ``` 三、优化数据库连接 1. 连接池:为了避免频繁地创建和销毁连接,可以...