对IFeatureClass的选择结果进行再次选择及排序
生活随笔
收集整理的這篇文章主要介紹了
对IFeatureClass的选择结果进行再次选择及排序
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
最近需要對IFeatureClass的選擇結果進行再次選擇,并對再次選擇的結果按照兩個屬性進行排序操作。于是先用IFeatureClass.Select方法進行第一次選擇,將選擇的結果用ISelectionSet類型變量SelectionSet1存放。然后需要對SelectionSet1中的要素進行再次選擇,并且對選擇結果進行排序,這時候問題就來了:用ISelectionSet.Search方法進行查詢選擇并排序時,如果在IQueryFilter.WhereClause選擇語句后面加上排序詞(order by xxx)就會報錯:SQL命令未正確結束。
問題:ISelectionSet.Search方法進行選擇不支持按屬性排序
?
原因:未搞清,疑為AE不支持或者自己方法不正確
?
解決方法:將第二次查詢結果SelectionSet1.Select通過ISelectionSet變量SelectionSet2進行存儲,然后使用ITableSort接口對SelectionSet2中的數據進行按屬性值排序。代碼如下:
ISelectionSet SelectionSet2= emptySelSet.Select(queryFilter,esriSelectionType.esriSelectionTypeHybrid,esriSelectionOption.esriSelectionOptionNormal,null);//存儲第二次查詢結果string strSortField = "CARID,TIME";//排序所需屬性 ITableSort pTableSort = new TableSort(); pTableSort.SelectionSet = SelectionSet2;//排序數據源輸入 pTableSort.Fields = strSortField; pTableSort.set_Ascending(strSortField,true);//選擇升序排列 pTableSort.Sort(null);IFeatureCursor emptyLineFeaCursor = pTableSort.Rows as IFeatureCursor;//排序結果輸出
轉載于:https://www.cnblogs.com/lettet/p/4329038.html
總結
以上是生活随笔為你收集整理的对IFeatureClass的选择结果进行再次选择及排序的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【转载】adb shell dumpsy
- 下一篇: 【Weiss】【第03章】练习3.7:有