ArcGIS Engine效率探究——要素的添加和删除、属性的读取和更新

来自:http://blog.csdn.net/freewaywalker/article/details/23703863

分类: ArcNotes2014-04-14 20:56 1781人阅读 评论(0) 收藏 举报

1. 要素的添加

ArcGIS Engine中,主要有两个方法用于要素的添加:

批量插入feature,如果用feature.store()方法,在图层中一个个地插入要素,较之同时使用insert cursor与feature buffer方法,会慢很多。

因为后者触发的事件和复杂行为比较少(比如说没有引发因拓扑关系产生的行为)。

2. 要素的删除

删除feature,一个个删除就用IFeature.Delete方法即可,此处不再赘述,只写一种批量删除的方法,用于ITable是针对数据库进行操作的,所以速度很快。

The best approach to take when deleting features depends on two factors, how many features are being deleted and whether the data source is a local geodatabase or an ArcSDE geodatabase.

In the simplest case, a single feature that has already been retrieved can be deleted by callingIFeature.Delete. If bulk features are being deleted and the geodatabase is an ArcSDE geodatabase, the most efficient approach requires the use of a search cursor and the IFeature.Delete method.

On the other hand, if the geodatabase is a local geodatabase (a file or personal geodatabase), the most efficient method for bulk deletion is theITable.DeleteSearchedRows method.

示例:

  1. ///<summary>
  2. ///删除某featurelayer中所有feature
  3. ///</summary>
  4. ///<param name="pLayer">操作的涂层</param>
  5. ///<remarks>该方法可以给一个queryfilter,进行删除符合条件的features</remarks>
  6. private void DeleteAllFeatures(IFeatureLayer pLayer, <code></code>IQueryFilter queryFilter)
  7. {
  8. ITable pTable = pLayer.FeatureClass as ITable;
  9. pTable.DeleteSearchedRows(queryFilter);
  10. }

3. 属性的读取

在获取属性表的值时有多种方法:

方法一:

  1. ITable pTable = pLayer.FeatureClass as ITable;
  2. clsFldValue = pTable.GetRow(i).get_Value(clsFldIndex);

方法二:

  1. IFeatureCursor FCursor = pLayer.FeatureClass.Search(new QueryFilterClass(), false);
  2. IFeature feature = FCursor.NextFeature();
  3. if (feature == null) return null;
  4. clsFldValue = feature.get_Value(clsFldIndex);
  5. feature = FCursor.NextFeature();

用Environment.TickCount进行代码执行时间测试,结果发现方法一读取整个表的时间为4984ms,而方法二读取同一个属性给的时间仅为32 ms,法二的执行效率是法一的156倍!!!

完整测试代码如下:

  1. IFeatureLayer pLayer = Utilities.GetLayerByName((string)cmbRegLayers.SelectedItem, m_mapControl) as IFeatureLayer;
  2. IFeatureCursor FCursor = pLayer.FeatureClass.Search(new QueryFilterClass(), false);
  3. IFeature feature = FCursor.NextFeature();
  4. int t = Environment.TickCount;
  5. object clsFldValue=null;
  6. for (int i = 0; i < pLayer.FeatureClass.FeatureCount(null); i++)
  7. {
  8. clsFldValue = feature.get_Value(3);
  9. feature = FCursor.NextFeature();
  10. }
  11. t = Environment.TickCount - t;
  12. MessageBox.Show(t.ToString());
  13. ITable pTable = pLayer.FeatureClass as ITable;
  14. t = Environment.TickCount;
  15. for (int i = 0; i < pTable.RowCount(null); i++)
  16. clsFldValue = pTable.GetRow(i).get_Value(3);
  17. t = Environment.TickCount - t;
  18. MessageBox.Show(t.ToString());

4.属性的更新

一、当将一批数据更新为某一相同的属性时,使用ITable.UpdateSearchedRows效率会很高。

示例如下:

  1. // Find the position of the field that will be updated.
  2. int typeFieldIndex = featureClass.FindField("TYPE");
  3. // Create a query filter defining which fields will be updated
  4. // (the subfields) and how to constrain which rows are updated
  5. // (the where clause).
  6. IQueryFilter queryFilter = new QueryFilterClass
  7. {
  8. SubFields = "TYPE", WhereClause = "LANE_COUNT = 4"
  9. };
  10. // Create a ComReleaser for buffer management.
  11. using(ComReleaser comReleaser = new ComReleaser())
  12. {
  13. // Create a feature buffer containing the values to be updated.
  14. IFeatureBuffer featureBuffer = featureClass.CreateFeatureBuffer();
  15. featureBuffer.set_Value(typeFieldIndex, "Highway");
  16. comReleaser.ManageLifetime(featureBuffer);
  17. // Cast the class to ITable and perform the updates.
  18. ITable table = (ITable)featureClass;
  19. IRowBuffer rowBuffer = (IRowBuffer)featureBuffer;
  20. table.UpdateSearchedRows(queryFilter, rowBuffer);
  21. }

二、逐条更新记录

这种方式中可有三种方法,如下:

(1)

  1. for (int i = 0; i < pTable.RowCount(null); i++)
  2. {
  3. pRow = pTable.GetRow(i);
  4. pRow.set_Value(2, i + 6);
  5. pRow.Store();
  6. }

(2)

  1. IFeatureCursor FCursor = pLayer.FeatureClass.Search(new QueryFilterClass(), false);
  2. IFeature feature = FCursor.NextFeature();
  3. for (int i = 0; i < featureNum; i++)
  4. {
  5. feature.set_Value(2, i);
  6. feature.Store();
  7. feature = FCursor.NextFeature();
  8. }

(3)

  1. ICursor pCursor =pTable.Update(null, false);
  2. pRow = pCursor.NextRow();
  3. for (int i = 0; i < pTable.RowCount(null); i++)
  4. {
  5. pRow.set_Value(2, i + 6);
  6. pCursor.UpdateRow(pRow);
  7. pRow = pCursor.NextRow();
  8. }

试验数据为320条记录,三种方法的运行时间为:法(1)为40297ms;法(2)34922ms为;法(3)为219ms.

可见运用IFeature和IRow的Store方法更新速度都很慢,用ICursor 的UpdateRow方法速度很快,分别是前两者效率的184倍、159倍!!

参考:

Creating features http://help.arcgis.com/en/sdk/10.0/arcobjects_net/conceptualhelp/index.html#//00010000049v000000

Updating Features http://help.arcgis.com/en/sdk/10.0/arcobjects_net/conceptualhelp/index.html#//0001000002rs000000

插入和删除Featureclass中feature的几种方法(VB.Net) http://www.cnblogs.com/wall/archive/2008/12/05/1348646.html

Arcengine效率探究之一——属性的读取 http://blog.csdn.net/lk103852503/article/details/6566652

Arcengine效率探究之二——属性的更新 http://blog.csdn.net/lk103852503/article/details/6570748

ArcGIS Engine效率探究——要素的添加和删除、属性的读取和更新的更多相关文章

  1. [转] ArcGIS engine中气泡标注的添加、修改

    小生 原文 ArcGIS engine中气泡标注的添加.修改! 你微微地笑着,不同我说什么话.而我觉得,为了这个,我已等待得久了.                                   ...

  2. vue组件上动态添加和删除属性

    1.vue组件上动态添加和删除属性 // 添加 this.$set(this.obj, 'propName', val) // 删除 this.$delete(this.obj, 'propName' ...

  3. arcgis engine 监听element的添加、更新和删除事件(使用IGraphicsContainerEvents)

    IGraphicsContainerEvents Interface 如何监听 element事件? 如,当我们在Mapcontrol上添加.删除.更新了一个Element后,如何捕捉到这个事件?   ...

  4. js 为对象添加和删除属性

    对于一个普通的js对象: var obj = { name:"mary", age:21 } 如果我们要对它添加新属性的话可以使用下列方式: obj.address = " ...

  5. 在js中为对象添加和删除属性

    对于一个普通的js对象: var obj = { name:"mary", age:21 } 如果我们要对它添加新属性的话可以使用下列方式: obj.address = " ...

  6. arcgis engine 监听element的添加、更新和删除事件(使用IMovePointFeedback)

    VB代码: 复制进程序稍作修改变量名和事件逻辑即可使用. Members   AllPropertiesMethodsInheritedNon-inherited Description Displa ...

  7. ArcEngine查询、添加、删除要素的方法

    原文 ArcEngine查询.添加.删除要素的方法 1.查找数据 1).利用FeaturCursor进行空间查询 //空间查询 ISpatialFilter spatialFilter = new S ...

  8. 使用Advanced Installer 自动部署 Arcgis Engine Runtime 10.0

    原文:使用Advanced Installer 自动部署 Arcgis Engine Runtime 10.0 目前采用Arcgis9.2 + c#(vs2008)作为程序开发平台,是一个不错的搭配. ...

  9. Arcgis engine 指定图层对要素进行创建、删除等操作

    Arcgis engine 指定图层创建点要素 在指定的图层上创建一个点要素,点要素的位置是通过X,Y坐标指定的,下面是具体的注释 .其中 和IFeatureClassWrite接口有关的代码不要好像 ...

随机推荐

  1. linux设置ssh连接时间

    相信大家经常遇到SSH连接闲置一会就断开需要重新连接的痛苦,为了使SSH连接保持足够长的时间,我们可以使用如下两种设置 1.sshd服务配置: #vi /etc/ssh/sshd_config Cli ...

  2. excel vba 高级过滤

    excel vba 高级过滤 Sub shaixuan() Dim database As Range '定义数据区域 Dim criteria_range As Range '定义条件区域 Dim ...

  3. xamarin 学习笔记01-环境配置

    1.安装AndroidSDK 参考 2.安装NDK NDK下载地址:http://dl.google.com/android/ndk/android-ndk-r10e-windows-x86_64.e ...

  4. ubuntu15.04安装 RVM

    首先,请参考这篇文章 https://ruby-china.org/wiki/rvm-guide RVM 官方网站 https://rvm.io/ 1 由于现在很多网站都转向https链接,所以,根据 ...

  5. centos7.2密码在单用户下面的修改

    centos7.2在但用户模式下面的修改 1.开机启动 2.grub模式按E健 3.Linux16行的"ro"修改为 "rw init=/sysroot/bin/sh&q ...

  6. Vue之x-template(2)

    将html结构写在一对script标签中,设置type=“x-template” <!DOCTYPE html> <html> <head lang="en&q ...

  7. ID字段不采用数据库自增长的几点理由

    一个小程序,最初采用了 SqlServer 数据库,后来为了便于部署,转而采用了 Firebird 嵌入式数据库.在重构代码转到 Firebird 的过程中,对“数据实体的数据表的ID字段是否应该使用 ...

  8. php使用命名空间时自动加载机制

    命名空间主要为了解决用户编写的代码与PHP内部的类/函数/常量或第三方类/函数/常量之间的名字冲突.不过并不是你定义了使用命名空间的类,就可以在任何地方随意使用了,需要在程序运行时将定义命名空间的类文 ...

  9. tomcat:页面跳转

    vim index.html <script language="javascript"type="text/javascript"> window ...

  10. windows 安装 python3

    安装python------------------------------------------------------------ 1,打开连接https://www.python.org/do ...