向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
来源:互联网 发布:滨州行知中学的邮编 编辑:程序博客网 时间:2024/04/29 03:58
写了一个小程序,从一个列表中读取坐标串,每个坐标串生成一个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();问题解决
原文地址:http://blog.csdn.net/rrrrssss00/article/details/6273642
- 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
- 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
- 向ArcSDE导入数据出现(ORA-00001: Unique contraint (SDE.GDB_OC_PKC) violated错误
- 向ArcSDE导入数据出现(ORA-00001: Unique contraint (SDE.GDB_OC_PKC) violated错误
- 出现ORA-12560问题的可能性以及相应的解决办法
- ORA-21500,ORA-24550,ORA-01000 ,ORA-06512同时出现,问题定位及解决办法
- imp导入时出现imp-00017 ora-06550的解决办法
- imp导入时出现imp-00017 ora-06550的解决办法
- imp导入时出现imp-00017 ora-06550的解决办法
- ORA-01795异常的原因以及解决办法
- ORA-00604,ORA-12705解决办法
- 关于向表中插入年月日时分秒且出现ORA-01810格式代码出现两次的错误时的解决办法
- kettle中抽取数据时ORA-01461错误的解决办法
- Oracle 数据库登录时出现ORA-12514 、ORA-01034、ORA-27101、ORA-01033 错误的解决
- IMP导入数据 出现ORA-01691问题 解决办法
- 登录 oracle 时 ORA-01034 和 ORA-27101 的解决办法
- ORA-16038 的解决办法
- ORA-31514的解决办法
- 在ARM+LINUX上使用pppd拔号上网(GPRS)流程
- IOS MapKit学习笔记
- ubuntu12.10 电源管理
- 看我是如何快速学习android开发的
- Never store the password unhased directly on the server!
- 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
- 上传文件
- iphone开发-地图注解(地图上的大头针)
- Eclipse和GTK版本的关系
- POJ 1010 STAMPS 解题报告
- as3 xml 操作
- Java之美[从菜鸟到高手演变]之设计模式
- 项目过程之间的关系
- HDU1431:素数回文