zoukankan      html  css  js  c++  java
  • 获取数据表中某字段唯一值

    获取某字段唯一值

    在做一般的数据处理时,要想得到某字段唯一值,我们可以利用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        }
  • 相关阅读:
    分页工具类
    ajax乱码的问题
    ibatis配置文件中的XML解析错误The content of elements must consist of well-formed character data or markup.
    nginx 反向代理导致的session丢失的问题
    后台返回的值ajax接收不到
    C/C++中vector与list的区别
    C/C++中内存泄漏、内存溢出与野指针的解释与说明
    C++中深拷贝与浅拷贝
    C++中的构造函数与析构函数及组合类的调用
    Linux中request_irq()中断申请与处理说明
  • 原文地址:https://www.cnblogs.com/3echo/p/478094.html
Copyright © 2011-2022 走看看