首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >java.sql.SQLException: ORA-01000:超出最大打开游标

java.sql.SQLException: ORA-01000:超出最大打开游标
EN

Stack Overflow用户
提问于 2015-01-30 12:09:38
回答 3查看 12.9K关注 0票数 0

我在ORA-01000 SQL异常上面得到了这个结果。

在我的DB中,一个有1500条记录的表,我正在尝试插入这些值。当插入到另一个表时,我得到了这个错误。

java.sql.SQLException: ORA-01000:超出最大打开游标 在oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112) at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:331) at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:288) at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:743) at oracle.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:213) at oracle.jdbc.driver.T4CPreparedStatement.executeForDescribe( oracle.jdbc.driver.OracleStatement.executeMaybeDescribe(OracleStatement.java:1031) at oracle.jdbc.driver.T4CPreparedStatement.executeMaybeDescribe(T4CPreparedStatement.java:836) at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1124) at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3285) at oracle.jdbc.driver.OraclePreparedStatement.executeUpdate(OraclePreparedStatement.java:3368) )在com.exceloid.newdb.NewDBInsertion.insertCLocation(NewDBInsertion.java:1239) at com.exceloid.dbmigration.CBPartnerImpl.getCLocationData(CBPartnerImpl.java:1198) at com.exceloid.serviceimpl.CBPartnerServiceImpl.doProcess(CBPartnerServiceImpl.java:22) at com.exceloid.controller.HomeController.cBPartner(HomeController.java:272) at com.exceloid.controller.HomeController.welcomePage(HomeController.java:37) at sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219) at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132)在org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:745) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:686) at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)在org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:936) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:827) at javax.servlet.http.HttpServlet.service(HttpServlet.java:617) atorg.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812) at javax.servlet.http.HttpServlet.service(HttpServlet.java:723) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) at org。apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) at org。apache.coyote.http11.Http11Processor.process(Http11Processor.java:861) at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:606) at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) at java.lang.Thread.run(Thread.java:745)

这是我的代码:

代码语言:javascript
复制
Connection connection = null;    
PreparedStatement pst = null;     
ResultSet result = null;    

try {      
            connection = newDbConnection(connection);     
            if(connection != null){      
                 for (CLocation cpayment : list) {    

                        cLocationId = cpayment.getcRegionID();    
                        adClient = cpayment.getAdClientID();    
                        adOrg = cpayment.getAdOrgID();    
                        updated = cpayment.getUpdated();     
                        updatedBy = cpayment.getUpdatedBy();    
                        created = cpayment.getCreated();    
                        createdBy = cpayment.getCreatedBy();    
                        isActive = cpayment.isActive();    
                        city = cpayment.getCity();   
                        postal = cpayment.getPostal();    
                        postalAdd = cpayment.getPostalAdd();    
                        cCountryId = cpayment.getcCountryID();    
                        cCityId = cpayment.getcCityID();    
                        address1 = cpayment.getAddress1();    
                        address2 = cpayment.getAddress2();    
                        cRegionId = cpayment.getcRegionID();   
                        regionName = cpayment.getRegionName();   

                        if(isActive == true) {    
                            InsertIsActive = "Y";    
                        } else {   
                            InsertIsActive = "N";    
                        } 

                        if(ad.equals(adClient)){    
                            final String sql = "SELECT * FROM c_location  where c_location_id = '"+cLocationId+"'";    
                            pst = connection.prepareStatement(sql);    
                            result = pst.executeQuery();    
                            boolean exist=result.next();    
                            if(exist){   
                                 System.out.println("already table data exists");    
                                 flag = true;    
                            } else {    
                                 String sql1="INSERT INTO c_location " + "    VALUES ('"+cLocationId+"', '"+client+"', '"+org+"', '"+InsertIsActive+"', '"+created+"', '"+createdBy+"', '"+updated+"', '"+updatedBy+"', '"+address1+"', '"+address2+"', '"+city+"', '"+postal+"', '"+postalAdd+"', '"+cCountryId+"', '"+cRegionId+"', '"+cCityId+"', '"+regionName+"')";   
                                 System.out.println(sql1);    
                                 pst=connection.prepareStatement(sql);    
                                 pst.executeUpdate();   
                                 flag = true;   
                            }    
                        } else {    
                            System.out.println("new db does not match adclient ID");    
                        }    
                 }     
            }     
        } catch (SQLException e) {    
            e.printStackTrace();     
        } finally {     
            if(result != null){     
                try{   
                    result.close();    
                }catch(Exception e){}    
            }    
            if(pst != null){    
                try{    
                    pst.close();    
                }catch(Exception e){}     
            }    
            if(connection != null){   
                try {    
                    connection.close();    
                } catch (SQLException e){}   
            }    
        }   

我已经关闭了所有的连接,但我仍然面临这个错误。

我已经在oracle控制台中执行了这个命令,以增加游标的no。

代码语言:javascript
复制
ALTER SYSTEM SET OPEN_CURSORS=1337 SID='*' SCOPE=BOTH;

但同样的错误再次发生。

EN

回答 3

Stack Overflow用户

发布于 2015-01-30 12:14:11

您只关闭最后一条SQL语句。

您正在遍历所有的CLocation,打开每个的CLocation语句,而不关闭单个的。执行之后,尝试关闭循环中的Prepared语句,因为每个语句都是在数据库端创建一个新的数据库服务器。

票数 2
EN

Stack Overflow用户

发布于 2015-01-30 12:14:52

将SQL语句更改为使用bind参数,并移出循环。

代码语言:javascript
复制
final String sql = "SELECT * FROM c_location  where c_location_id = ?";    
pst = connection.prepareStatement(sql);

在循环中设置绑定参数。

代码语言:javascript
复制
pst.setString(1, cLocationId);

对于INSERT语句也应该这样做。

票数 2
EN

Stack Overflow用户

发布于 2015-01-30 12:17:34

重写代码以使用“尝试-使用-资源”构造。

请参阅:with

还可以使用绑定变量。它将更短,更安全,甚至更快。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28235626

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档