ArcGIS Engine 10 开发手册(11-2)排序相关接口
        
          发布时间: 2018-02-17        
        
          所属分类: ArcGIS Engine 10 开发手册
        
        
              
      
      
      
      在处理数据时,有时候需要对数据进行升序和降序排序,我们一贯的做法是在 ArcMap 中,在排序的 字段上右键,然后点击排序操作,可是当我们关闭这个数据后,重新打开属性表,发现顺序又变回去了, 更甚者,我们将数据排序之后,然后利用 ArcMap 倒出去,但是结果不是我们想要的,对于这样的问题 ArcGIS Engine 提供了一个 ITableSort 的接口,该接口可以实现我们想要的功能。ITableSort 接口包含以下属性和方法:

示例:利用ITableSort对要素类排序
/// <summary>
/// true 表示升序,false 表示降序
/// </summary>
/// <param name="_pTable"></param>
/// <param name="_FieldName"></param>
/// <param name="_Bool"></param>
void Sort (ITable _pTable, string _FieldName, bool _Bool)
{
  ITableSort pTableSort = new TableSortClass ();
  pTableSort.Table = _pTable;
  pTableSort.Fields = _FieldName;
  pTableSort.set_Ascending (_FieldName, _Bool);
  pTableSort.Sort (null);
  ICursor pSortCursor = pTableSort.Rows;
  IRow pSortRow = pSortCursor.NextRow ();
  IDataset plSortDataset = _pTable as IDataset;
  IFeatureWorkspace pFWs = plSortDataset.Workspace as IFeatureWorkspace;
  ITable plStable = pFWs.CreateTable ("NewSort", _pTable.Fields, null, null, null);
  while (pSortRow != null)
  {
    IRow pRow = plStable.CreateRow ();
    for (int i = 0; i < pRow.Fields.FieldCount; i++)
    {
      if (pRow.Fields.get_Field (i).Type != esriFieldType.esriFieldTypeOID)
      {
        pRow.set_Value (i, pSortRow.get_Value (i));
      }
    }
    pRow.Store ();
    pSortRow = pSortCursor.NextRow ();
  }
}
运行结果

ArcGIS Engine 10 开发手册全集
ArcGIS Engine 10 开发手册全集: ArcGIS Engine 10 开发手册
相关阅读
声明
1.本文所分享的所有需要用户下载使用的内容(包括但不限于软件、数据、图片)来自于网络或者麻辣GIS粉丝自行分享,版权归该下载资源的合法拥有者所有,如有侵权请第一时间联系本站删除。
2.下载内容仅限个人学习使用,请切勿用作商用等其他用途,否则后果自负。
手机阅读
          公众号关注
          知识星球
          
              手机阅读
            
           
            
              最新GIS干货
            
           
            
              私享圈子
            
           
     
               
               
               
               
               
               
           
           
           
           
                     
                     
                     
                     
                     
                     
                     
                     
                 
                 
                 
                 
                     
                     
                     
                     
                     
                     
                     
                     
                     
                 
                 
                 
                 
                 
                 
                