向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
2011-03-24 11:28
381 查看
写了一个小程序,从一个列表中读取坐标串,每个坐标串生成一个IPolygon,然后将这些Polygon添加到一个SDE图层中,
向SDE中添加要素的初始代码类似下面:
要素较少时可以正确地写入SDE图层,但大概超过300个左右,之后就会报这个错误:“ORA-00604: 递归 SQL 级别 1 出现错误,ORA-01000: 超出打开游标的最大数”,环境是ArcSDE9.3 + Oralce9i(之后还在ArcSDE9.3 + Oracle10g的环境里做了测试,结果基本相同,但将目标图层换为FileGDB图层后,没有出现该问题,说明应该是Oracle数据库的相关设置的原因)。
联系ESRI技术支持,说可能是游标没有释放的问题,而且谈到在向FeatureClass中添加大量数据时,使用IFeatureCursor效率会比较高,而且可以通过将IFeatureCursor释放的方法来避免出现这个问题,代码修改为:
修改后,问题依旧,再咨询ESRI技术支持后,可能是相关资源没有自动回收的原因,在代码最后加上GC.Collect();问题解决
向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();问题解决
相关文章推荐
- 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
- 向SDE图层中添加大量数据时,出现ORA-00604以及ORA-01000的解决办法
- 清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- 【转】ArcGIS问题:清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- 【转】ArcGIS问题:清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- IMP导入数据 出现ORA-01691问题 解决办法
- 清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- 出现ORA-12560问题的可能性以及相应的解决办法
- IMP导入数据 出现ORA-01691问题 解决办法
- 清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- VS中添加lib文件,以及出现LINK : fatal error LNK1104: 无法打开文件:×××.lib的解决办法
- IMP导入数据 出现ORA-01691问题 解决办法
- 清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- java导出excel大量数据出现错误时解决办法
- 转:清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- 清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- 清除arcsde空间垃圾数据以及解决sde图层名称被占用的问题
- Controller中执行一段时间后出现错误"ORA-01000: maximum open cursors exceeded"解决办法
- “java.sql.SQLException: ORA-00604: 递归 SQL 级别 1 出现错误”的解决办法
- ORA-21500,ORA-24550,ORA-01000 ,ORA-06512同时出现,问题定位及解决办法