ArcGIS Engine空间查询功能的实现(QueryFilterClass+SpatialFilterClass)

地图中包含大量的信息,为了快速地了解所需信息,必须借助为空间数据专门编写的空间查询功能

空间查询主要有两种类型

基于属性的查询,也称为属性查询

基于空间位置的查询,也称为空间查询

 

查询类的基本思路(适用于属性查询以及空间查询)

ArcGIS Engine空间查询功能的实现(QueryFilterClass+SpatialFilterClass)

 

 

 

 

1、属性查询

基于属性的查询,即属性查询,是通过对要素的属性信息设定查询条件来查询、定位空间位置

QueryFilterClass是专门用于属性查询的属性查询过滤器。

被称为过滤器是因为拥有WhereClause属性——能够设置查询条件的Sql语句。

 

注意:

使用WhereClause应该注意以下几点:
(1)大小写——字段值不区分大小写。
(2)通配符的使用——“?”代表单个字符,“*”代表一组字符。
(3)不支持Orderby关键字,可以通过ITablesort接口完成。

 

2、空间查询

基于空间位置查询,即空间查询,是根据要素之间的空间位置关系进行的查询,查询结果包括了被查询对象的空间信息以及属性信息

SpatialFilterClass对象类被称为空间查询过滤器。它是属性过滤器的子类,它拥有的ISpatialFilter也继承了IQueryFilter接口。

因此,空间查询过滤器既能进行空间查询也能进行属性查询。

 

一般地,要素之间的空间关系,即查询范围与被查询对象的空间关系主要有以下几种:

 

相交(Intersect)、叠加(Overlap)、穿越(Cross)、在内部(Within)和包含(Con-tain)。

空间关系(SpatialRel)属性成员不需要用户自定义,系统以枚举常量的方式(即ESRISpatialRelEnum)向用户提供了多种空间关系。

(1)ESRISpatialRellntersects:空间相交

(2)ESRISpatialRelTouches:空间相接

(3)ESRISpatialRelOverlaps:覆盖

(4)ESRISpatialRelCrosses:穿越

(5)ESRISpatialRelWithin:在内部

(6)ESRISpatialRelContains:包含

 

I.数据类型转换(底层模块)

/// <summary> /// 转换数据类型 /// </summary> /// <param></param> /// <returns></returns> private static string ParseFieldType(esriFieldType FieldType) { switch (FieldType) { case esriFieldType.esriFieldTypeInteger: return "System.Int32"; case esriFieldType.esriFieldTypeOID: return "System.Int32"; case esriFieldType.esriFieldTypeDouble: return "System.Double"; case esriFieldType.esriFieldTypeDate: return "System.DateTime"; default: return "System.String"; } }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zwfxws.html