java.sql.SQLException: ORA-00604: 递归 SQL 级别 1 出现错误
2016-08-15 15:29
309 查看
后台报出如下错误:
Caused by: java.sql.SQLException: ORA-00604: 递归 SQL 级别 1 出现错误
ORA-01000: 超出打开游标的最大数
ORA-00604: 递归 SQL 级别 1 出现错误
ORA-01000: 超出打开游标的最大数
ORA-01000: 超出打开游标的最大数
原因:
这个错误一般出现在利用代码循环执行数据库命令(例如将数据导入到数据库或者定时任务向数据库中插入数据)时,例如在java中
1.建立一个Connection
2.循环创建PreparedStatement,并执行数据导入
3.关闭OracleConnection
当第二步的循环数比较小时,代码运行正常。当循环数超过一定值(例如300),代码就会出错。提示:
ORA-01000: 超出打开游标的最大数
Oracle数据库中打开的游标最大数为一定值,默认情况下是300,当代码到第二步时, 循环中一个PreparedStatement占用了一个数据库游标,执行的循环超过这个数时就会产生游标数目溢出错误。
解决办法:
第二步循环中每次执行完PreparedStatement,都将PreparedStatement.close()下,释放掉这个资源就好了
此外,也可以修改数据库的最大游标数,不过这个方法治标不治本。( alter system set open_cursors=1000 scope=both; )
Caused by: java.sql.SQLException: ORA-00604: 递归 SQL 级别 1 出现错误
ORA-01000: 超出打开游标的最大数
ORA-00604: 递归 SQL 级别 1 出现错误
ORA-01000: 超出打开游标的最大数
ORA-01000: 超出打开游标的最大数
原因:
这个错误一般出现在利用代码循环执行数据库命令(例如将数据导入到数据库或者定时任务向数据库中插入数据)时,例如在java中
1.建立一个Connection
2.循环创建PreparedStatement,并执行数据导入
3.关闭OracleConnection
当第二步的循环数比较小时,代码运行正常。当循环数超过一定值(例如300),代码就会出错。提示:
ORA-01000: 超出打开游标的最大数
Oracle数据库中打开的游标最大数为一定值,默认情况下是300,当代码到第二步时, 循环中一个PreparedStatement占用了一个数据库游标,执行的循环超过这个数时就会产生游标数目溢出错误。
解决办法:
第二步循环中每次执行完PreparedStatement,都将PreparedStatement.close()下,释放掉这个资源就好了
此外,也可以修改数据库的最大游标数,不过这个方法治标不治本。( alter system set open_cursors=1000 scope=both; )
相关文章推荐
- Retrofit结合RxJava个人使用经验
- 第一个Java程序
- 第一个Java程序
- 第一个Java程序
- java基础——实现线程串行执行
- Java 面向对象
- Spring+SpringMVC
- Spring中使用Map、Set、List、数组、属性集合的注入方法配置文件
- java基础——串行与并行
- Eclipse编程助手
- Java 面向对象之 继承
- 可见性修饰符
- JavaEE——properties配置文件的编写和解析获取
- Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)
- java连接MySQL数据库的超强版
- 10013---69道Spring面试题和答案
- myeclipse内存不足问题
- JAVA 处理时间 - java.sql.Date、java.util.Date与数据库中的Date字段的转换方法[转]
- Java坑一
- MyEclipse个性化代码注释模板