`
guzizai2007
  • 浏览: 360439 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

PreparedStatement连续赋值未关闭:ORA-01000: maximum open cursors exceeded

 
阅读更多

问题代码:

for循环中调用一个方法,方法大致如下:
preparedstatement ps = null;

String sql1 = ".....";
ps= connection.preparestatement(sql1);
ps.executequery();

String sql2 = "......";
ps= connection.preparestatement(sql2);
ps.executequery();

String sql3 = "......";
ps= connection.preparestatement(sql3);
ps.executequery();

解决办法:

preparedstatement ps = null;

String sql1 = ".....";
ps= connection.preparestatement(sql1);
ps.executequery();
ps.close();

String sql2 = "......";
ps= connection.preparestatement(sql2);
ps.executequery();
ps.close();

String sql3 = "......";
ps= connection.preparestatement(sql3);
ps.executequery();
ps.close();

 查询Oracle数据库会话最大游标数:

SQL> show parameter open_cursors;
NAME                  TYPE        VALUE
--------------------- ----------- -----------
open_cursors     integer     1500

 

 

分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    ora-01460 错误原因分析

    ### ORA-01460 错误原因分析 #### 概述 在Oracle数据库操作过程中,可能会遇到ORA-01460错误,该错误全称为“ORA-01460: 转换请求无法实现或不合理”。这一错误通常发生在数据类型转换或者与操作系统之间的数据...

    JDBC驱动for sqlserver、oracle、mysql

    在实际应用中,为了提高性能和资源利用率,通常会使用连接池(如C3P0、HikariCP、Apache DBCP等),预先创建并管理一组数据库连接,避免频繁地创建和关闭连接。 7.事务处理: JDBC支持事务管理,通过...

    oracle数据库的clob大字段在jdbc中的处理方式

    在实际应用中,还可能涉及CLOB字段的写入操作,这通常可以通过`PreparedStatement`的`setClob()`方法实现,将String转换为`Clob`对象(可以使用`OracleConnection`的`createClob()`方法创建)后再设置到SQL语句中。...

    ORACLE技术文档\oracle cursor 游标.doc

    当一个应用程序尝试打开过多的游标时,可能会遇到`ORA-01000: maximum open cursors exceeded`错误,这表明单个用户尝试打开的游标数量超过了系统允许的最大值。 `ORA-01000`错误的主要原因通常是程序设计不当,...

    mysql-connector-java-5.1.47

    3. **Statement和PreparedStatement**:`java.sql.Statement`用于执行SQL查询,而`PreparedStatement`则预编译SQL语句,提供更好的性能和安全性,尤其是当你需要多次执行相同查询时。 4. **ResultSet**:当执行查询...

    c3po连接池参数配置

    - 作用:控制连接关闭时的事务状态,有助于保证数据的一致性和安全性。 ##### 5. **automaticTestTable** - 配置描述:用于测试连接的表名。 - 默认值:null - 作用:指定一个测试表,用于检查数据库连接的有效...

    mysql数据库驱动:mysql-connector-java-6.0.5.jar

    JDBC接口主要包括Connection(连接)、Statement(语句)、PreparedStatement(预编译语句)和ResultSet(结果集)等核心类。 4. **连接管理**: 使用这个驱动,开发者可以通过`DriverManager.getConnection()`方法...

    mysql 连接驱动 mysql-connector-java-5.1.46.jar

    6. 关闭资源:在完成数据库操作后,记得关闭ResultSet、Statement和Connection,以释放系统资源。 `mysql-connector-java-5.1.46.jar`版本号中的5.1表示它兼容MySQL 5.1.x版本。然而,随着MySQL版本的更新,新的...

    gbase-jdbc驱动gbase-connector-8.3.81.51和infomix驱动ifxjdbc.jar

    使用JDBC的基本步骤包括加载驱动、建立连接、创建Statement或PreparedStatement对象、执行SQL以及关闭连接。 4. **连接数据库**: 在Java应用中,使用这两个驱动连接数据库的基本步骤如下: - 加载驱动:`Class....

    JavaSE程序设计课件:L07-Java Database Programming - 1.pdf

    6. 关闭资源:完成数据库操作后,记得关闭ResultSet、Statement和Connection,释放系统资源。 在实际应用中,通常还会使用DAO(Data Access Object)模式来封装数据库操作,以提高代码的可复用性和可维护性。此外,...

    oracle数据库小结

    接下来,我们讨论一个常见的Oracle错误:ORA-01000: maximum open cursors exceeded,即打开的游标数量超过了允许的最大值。这通常发生在频繁使用预编译语句(PreparedStatement)的场景中。解决这个问题有以下几个...

    mysql-connector-java-5.1.7-5.1.3-5.1.17

    `PreparedStatement`更安全且效率更高,因为它支持预编译的SQL语句,防止SQL注入攻击。 4. **结果集处理**:`ResultSet`对象用于存储查询返回的结果。开发者可以通过迭代`ResultSet`来获取每一行数据,并访问每个...

    mysql-connector-java-5.1.47.zip

    6. **关闭资源**:在操作完成后,记得关闭 `Statement`、`ResultSet` 和 `Connection`,以释放系统资源。 7. **连接池**:在实际应用中,为了提高性能和效率,通常会使用连接池(如 C3P0、HikariCP 或 DBCP)管理...

    mysql-connector-java-5.1.29.tar.gz

    4. **Statement和PreparedStatement**: Statement用于执行静态SQL语句,而PreparedStatement则用于执行预编译的SQL语句,它支持参数化查询,提高了性能并降低了SQL注入的风险。 5. **ResultSet**: 当我们执行查询...

    2021-2022计算机二级等级考试试题及答案No.1706.docx

    - 关闭计算机前,应当确保将重要数据保存到非易失性存储器中,如硬盘等。 - 正确答案:错误。 #### 15. 应用软件示例 - **应用软件**:是指用于特定目的的软件,如 Word、Excel 等。 - 正确答案:正确。 #### 16....

    gbase-connector-java

    4. **创建Statement或PreparedStatement**:根据需求,我们可以创建`Statement`对象来执行静态SQL语句,或者创建`PreparedStatement`对象来执行预编译的SQL语句,这有助于防止SQL注入攻击。 5. **执行SQL**:使用`...

    connection 和 preparedstatement 的关闭问题

    ### Connection 和 PreparedStatement 的关闭问题 在Java编程语言中,处理数据库连接及执行SQL语句时,合理地管理和释放资源是非常重要的。本文将详细介绍`Connection`和`PreparedStatement`的使用时机与关闭策略,...

    JDBC问题解决的方法

    - **资源关闭**:在使用完`Statement`、`ResultSet`和`Connection`后,记得关闭它们,防止内存泄漏。 - **结果集遍历**:正确使用`ResultSet`的`next()`方法,避免越界。 5. **性能优化** - **批处理**:批量...

    Jdbc相关知识点归档.rar

    - 创建Statement或PreparedStatement对象,用于执行SQL。 - 执行SQL:Statement的executeQuery()或executeUpdate()方法。 - 处理结果集:ResultSet rs = stmt.executeQuery()。 - 关闭资源:rs.close(), stmt....

Global site tag (gtag.js) - Google Analytics