AE中获取数据表中某字段唯一值

 

在做一般的数据处理时,要想得到某字段唯一值,我们可以利用 SQL 语言之关键字 Distinct 方便地获得。但是在用 AE 作开发时,我们应该怎样去做呢?当然我们可以首先获得某个字段的所有值,然后再去比较、提取、获得唯一值。这样的工作写起来麻烦,效率也非常低。其实 AE 类库 ESRI.ArcGIS.Geodatabase 之接口 IDataStatistics 已为我们提供了这样的方法。

 

 

 

ArcGIS 开发帮助文档有很多示例,大都都是用 VB 或是 VBA 编写,下面是本人利用 C#+AE9.1 编写的示例:

 1          ///   <summary>
 2          ///  得到要素类某字段的唯一值
 3          ///   </summary>
 4          ///   <param name=”pFeatureClass”> 要素类 </param>
 5          ///   <param name=”strFld”> 指定要得到唯一值的字段 </param>
 6          ///   <returns> 唯一值字符数据 </returns>
 7          public   static   string [] GetUniqueValue(IFeatureClass pFeatureClass, string  strFld)
 8          {
 9              // 得到IFeatureCursor游标
10             IFeatureCursor pCursor = pFeatureClass.Search( null , false );
11
12              // coClass对象实例生成
13             IDataStatistics pData = new  DataStatisticsClass();
14             pData.Field = strFld;
15             pData.Cursor = pCursor  as  ICursor;
16
17              // 枚举唯一值
18             IEnumerator pEnumVar = pData.UniqueValues ;
19
20              // 记录总数
21              int  RecordCount = pData.UniqueValueCount;
22
23              // 字符数组
24              string [] strValue = new   string [RecordCount];   
25             pEnumVar.Reset();
26         
27              int  i = 0 ;
28
29              while (pEnumVar.MoveNext())
30              {
31                 strValue[ ++ i] = pEnumVar.Current.ToString();
32             }
            
33    
34              return  strValue;
35         }

 

 

 

 1          /**/ ///   <summary>
 2          ///  得到要素类某字段的唯一值
 3          ///   </summary>
 4          ///   <param name=”pFeatureClass”> 要素类 </param>
 5          ///   <param name=”strFld”> 指定要得到唯一值的字段 </param>
 6          ///   <returns> 唯一值字符数据 </returns>
 7          public   static   string [] GetUniqueValue(IFeatureClass pFeatureClass, string  strFld)
 8          {
 9              // 得到IFeatureCursor游标
10             IFeatureCursor pCursor = pFeatureClass.Search( null , false );
11
12              // coClass对象实例生成
13             IDataStatistics pData = new  DataStatisticsClass();
14             pData.Field = strFld;
15             pData.Cursor = pCursor  as  ICursor;
16
17              // 枚举唯一值
18             IEnumerator pEnumVar = pData.UniqueValues ;
19
20              // 记录总数
21              int  RecordCount = pData.UniqueValueCount;
22
23              // 字符数组
24              string [] strValue = new   string [RecordCount];   
25             pEnumVar.Reset();
26         
27              int  i = 0 ;
28
29              while (pEnumVar.MoveNext())
30              {
31                 strValue[ ++ i] = pEnumVar.Current.ToString();
32             }
            
33    
34              return  strValue;
35         }

转载自:https://blog.csdn.net/aureate820/article/details/2197048

You may also like...