zoukankan      html  css  js  c++  java
  • 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法

    转自原文 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法

    写了一个小程序,从一个列表中读取坐标串,每个坐标串生成一个IPolygon,然后将这些Polygon添加到一个SDE图层中,
    向SDE中添加要素的初始代码类似下面:

    IWorkspaceEdit workspaceEdit = (IWorkspaceEdit)workspace;  
    workspaceEdit.StartEditing(true);  
    workspaceEdit.StartEditOperation();  
    for(int i=0;i<polygons.count;i++)  
    {  
        IFeature tmpFea = fc.CreateFeature();           //fc是图层对应的IFeatureClass  
            tmpFea.Shape = GetPolygonFromCoord(polygons[i]);  
        tmpFea.Store();    
    }  
    workspaceEdit.StartEditing(true);  
    workspaceEdit.StartEditOperation();  

    要素较少时可以正确地写入SDE图层,但大概超过300个左右,之后就会报这个错误:“ORA-00604: 递归 SQL 级别 1 出现错误,ORA-01000: 超出打开游标的最大数”,环境是ArcSDE9.3 + Oralce9i(之后还在ArcSDE9.3 + Oracle10g的环境里做了测试,结果基本相同,但将目标图层换为FileGDB图层后,没有出现该问题,说明应该是Oracle数据库的相关设置的原因)。
    联系ESRI技术支持,说可能是游标没有释放的问题,而且谈到在向FeatureClass中添加大量数据时,使用IFeatureCursor效率会比较高,而且可以通过将IFeatureCursor释放的方法来避免出现这个问题,代码修改为:

    IWorkspaceEdit workspaceEdit = (IWorkspaceEdit)workspace;  
    workspaceEdit.StartEditing(true);  
    workspaceEdit.StartEditOperation();  
    IFeatureBuffer featureBuffer = fc.CreateFeatureBuffer();        //fc是图层对应的IFeatureClass  
    IFeatureCursor featureCursor = fc.Insert(true);  
    for(int i=0;i<polygons.count;i++)  
    {  
        featureBuffer.set_Value(featureBuffer.Fields.FindField("PRODUCTID"), id);  
            featureBuffer.Shape =  GetPolygonFromCoord(polygons[i]);  
            object featureOID = featureCursor.InsertFeature(featureBuffer);  
    }  
    featureCursor.Flush();  
    workspaceEdit.StartEditing(true);  
    workspaceEdit.StartEditOperation();  
    System.Runtime.InteropServices.Marshal.ReleaseComObject(featureCursor);  

    修改后,问题依旧,再咨询ESRI技术支持后,可能是相关资源没有自动回收的原因,在代码最后加上GC.Collect();问题解决。

  • 相关阅读:
    linux上安装mysql
    linux 上nginx配置
    js人民币数字转大写
    pm2常用命令
    基于redis实现分布式锁
    Enterprise Architect 14破解版 安装包 安装教程
    一些有用的链接
    Linux安装Zookeeper
    根据朋友圈的网易云音乐分享找到人
    我的待做事项
  • 原文地址:https://www.cnblogs.com/arxive/p/6262458.html
Copyright © 2011-2022 走看看