向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();问题解决。

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。


    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/6262458.html ,如需转载请自行联系原作者


相关实践学习
基于函数计算一键部署掌上游戏机
本场景介绍如何使用阿里云计算服务命令快速搭建一个掌上游戏机。
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
Oracle 关系型数据库
Oracle 物理 DG 转 ADG 步骤
DataGuard 物理备库,正常为 mount 状态,如果想要进行查询,需要转为 ADG,即 read only 状态!
Oracle 物理 DG 转 ADG 步骤