zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    20200601:百万级int数据量的一个array求和。
    20200602:千万级数据量的list找一个数据。
    20200531:假如Redis里面有1亿个key,其中有10w个key是以某个固定的已知的前缀开头的,如何将它们全部找出来?
    20200530:主从数据库不一致如何解决?
    [USACO06DEC]Milk Patterns G
    [HAOI2016]找相同字符
    [AHOI2013]差异
    [SCOI2012]喵星球上的点名
    [APIO2014]回文串
    [TJOI2015]弦论
  • 原文地址:https://www.cnblogs.com/lqqgis/p/12642832.html
Copyright © 2011-2022 走看看