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

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

[c-sharp]  view plain copy
  1. IWorkspaceEdit workspaceEdit = (IWorkspaceEdit)workspace;  
  2. workspaceEdit.StartEditing(true);  
  3. workspaceEdit.StartEditOperation();  
  4. for(int i=0;i<polygons.count;i++)  
  5. {  
  6.     IFeature tmpFea = fc.CreateFeature();           //fc是图层对应的IFeatureClass  
  7.         tmpFea.Shape = GetPolygonFromCoord(polygons[i]);  
  8.     tmpFea.Store();    
  9. }  
  10. workspaceEdit.StartEditing(true);  
  11. workspaceEdit.StartEditOperation();  

 


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

 

[c-sharp]  view plain copy
  1. IWorkspaceEdit workspaceEdit = (IWorkspaceEdit)workspace;  
  2. workspaceEdit.StartEditing(true);  
  3. workspaceEdit.StartEditOperation();  
  4. IFeatureBuffer featureBuffer = fc.CreateFeatureBuffer();        //fc是图层对应的IFeatureClass  
  5. IFeatureCursor featureCursor = fc.Insert(true);  
  6. for(int i=0;i<polygons.count;i++)  
  7. {  
  8.     featureBuffer.set_Value(featureBuffer.Fields.FindField("PRODUCTID"), id);  
  9.         featureBuffer.Shape =  GetPolygonFromCoord(polygons[i]);  
  10.         object featureOID = featureCursor.InsertFeature(featureBuffer);  
  11. }  
  12. featureCursor.Flush();  
  13. workspaceEdit.StartEditing(true);  
  14. workspaceEdit.StartEditOperation();  
  15. System.Runtime.InteropServices.Marshal.ReleaseComObject(featureCursor);  

 

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


原文地址:http://blog.csdn.net/rrrrssss00/article/details/6273642

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值