ArcObject 要素删除
1 四种删除方法
1.1 FeatureClass.Search() 查询游标删除
private void Delete01(IFeatureClass featureclass)
{
IQueryFilter queryFilter = new QueryFilterClass();
queryFilter.WhereClause = "objectID <= " + DeleteNum;
IFeatureCursor featureCursor = featureclass.Search(queryFilter, false);
IFeature feature = null ;
while ((feature = featureCursor.NextFeature())!= null)
{
feature.Delete();
}
System.Runtime.InteropServices.Marshal.ReleaseComObject(featureCursor);
}
1.2 FeatureClass.Update() 更新游标删除
private void Delete02(IFeatureClass featureclass)
{
IQueryFilter queryFilter = new QueryFilterClass();
queryFilter.WhereClause = "objectID <= " + DeleteNum;
IFeatureCursor featureCursor = featureclass.Update(queryFilter, false);
IFeature feature = null ;
while ((feature = featureCursor.NextFeature())!= null)
{
feature.Delete();
}
System.Runtime.InteropServices.Marshal.ReleaseComObject(featureCursor);
}
1.3 ITable.DeleteSearchedRows() 删除
private void Delete03(IFeatureClass featureclass)
{
IQueryFilter queryFilter = new QueryFilterClass();
queryFilter.WhereClause = "objectID <= " + DeleteNum;
ITable table = featureclass as ITable;
table.DeleteSearchedRows(queryFilter);
}
1.4 IWorkspace.ExecuteSQL() 删除
private void Delete04(IFeatureClass featureclass)
{
IDataset dataset = featureclass as IDataset;
dataset.Workspace.ExecuteSQL("delete from " + featureclass.AliasName + " where objectid <= " + DeleteNum);
}
2 删除方法效率对比
2.1 测试代码
相同的数据条件,删除2000条记录
代码如下:
IFeatureLayer pFeatureLayer = axMapControl1.Map.get_Layer(0) as IFeatureLayer;
IFeatureClass PFeatureClass = pFeatureLayer.FeatureClass;
System.Diagnostics.Stopwatch MyWatch = new System.Diagnostics.Stopwatch();
MyWatch.Start();
Delete01(PFeatureClass)
//Delete02(PFeatureClass);
//Delete03(PFeatureClass);
//Delete04(PFeatureClass);
MyWatch.Stop();
MessageBox.Show("删除时间:" + MyWatch.ElapsedMilliseconds.ToString() + "毫秒");
2.2 测试结果
方法 | 第一次时间(单位ms) | 第二次时间(单位ms) |
---|---|---|
Delete01 | 5214ms | 5735ms |
Delete02 | 299ms | 290Ms |
Delete03 | 59ms | 58ms |
Delete04 | 26ms | 26ms |
分类:
ArcObject
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人