一、开发环境
开发环境为ArcGIS Engine 10.2与Visual studio2010。在使用ArcEngine查询进行查询的时候主要使用三种查询接口IQueryFilter(属性查询) 、ISpatialFilter(空间查询) 、IQueryDef (多表查询)
那么这三个接口的区别是什么呢?
| 要求 | IQueryFilter | ISpatialFilter | IQueryDef |
|---|---|---|---|
| 属性约束 | True | True | True |
| 空间约束 | False | True | False |
| 查询结果包括多个表的字段 | False | False | True |
| 查询结果返回一个游标 | True | True | True |
| RecordSet对象可以从结果中创建 | True | True | True |
| 返回的记录可以被编辑 | True | True | False |
| 记录集包括在活动编辑会话中进行的编辑 | True | True | False |
从上面的表格可以看出IQueryFilter、IQueryDef 都可以进行属性查询,ISpatialFilter可以进行空间查询。
这是最常见的属性查询,输入WhereClause条件用于获取或设置查询过滤条件,然后调用IFeatureClass或者ITable的Search方法就行了。
- private void 属性查询ToolStripMenuItem_Click(object sender, EventArgs e)
- {
- try
- {
- //判断第一个图层是否是矢量图层,如果是则开始属性查询,如果不是程序不再执行
- if (axMapControl1.get_Layer(0) is IFeatureLayer)
- {
- //把第一个图层强制转换为要素类图层
- IFeatureLayer pFeatureLayer = axMapControl1.get_Layer(0) as IFeatureLayer;
- //创建一个QueryFilter对象
- IQueryFilter pQueryFilter = new QueryFilter();
- //输入查询过滤条件【查询当前要素类 FID为1或2的要素】
- pQueryFilter.WhereClause = "FID = 1 or FID = 2";
- IFeatureSelection pFeatureSelection = pFeatureLayer as IFeatureSelection;
- //进行空间查询,并加入选择集
- pFeatureSelection.SelectFeatures(pQueryFilter, esriSelectionResultEnum.esriSelectionResultNew, false);
- //刷新主地图进行高亮显示,一般用局部刷新
- axMapControl1.Refresh();
- }
- }
- catch (Exception ex)
- {
- MessageBox.Show("请先加载数据后再进行查询!","",MessageBoxButtons.OK,MessageBoxIcon.Warning);
- }
- }
2.ISpatialFilter接口
- #region 通过点击主地图的面状图形,获取其临近要素
- private void axMapControl1_OnMouseDown(object sender, IMapControlEvents2_OnMouseDownEvent e)
- {
- try
- {
- //清空地图选择集
- axMapControl1.ActiveView.FocusMap.ClearSelection();
- //实例化一个点,以该点作拓扑算子,将点击的位置坐标赋予pPoint
- IPoint pPoint = new ESRI.ArcGIS.Geometry.Point();
- ITopologicalOperator pTopologicalOperator = pPoint as ITopologicalOperator;
- pPoint.PutCoords(e.mapX, e.mapY);
- //以缓冲半径为0进行缓冲 得到一个点
- IGeometry pGeometry = pTopologicalOperator.Buffer(0);
- //以该点进行要素选择(只能选中面状要素,点和线无法选中)
- axMapControl1.Map.SelectByShape(pGeometry, null, false);
- //刷新视图
- axMapControl1.Refresh(esriViewDrawPhase.esriViewGeoSelection, null, null);
- // 获取选择集
- ISelection pSelection = axMapControl1.Map.FeatureSelection;
- // 获取要素
- IEnumFeature pEnumFeature = pSelection as IEnumFeature;
- IFeature pFeature = pEnumFeature.Next();
- while (pFeature != null)
- {
- //定义一个空间查询对象
- ISpatialFilter spatialFilter = new SpatialFilter();
- //空间查询对象为点选的的几何对象
- spatialFilter.Geometry = pFeature.Shape;
- //设置空间查询关系为 空间临接查询
- spatialFilter.SpatialRel = esriSpatialRelEnum.esriSpatialRelTouches;
- //遍历axMapControl1中的所有图层
- for (int i = 0; i < axMapControl1.LayerCount; i++)
- {
- //清空地图选择集
- axMapControl1.ActiveView.FocusMap.ClearSelection();
- //判断当前图层是否为矢量图层
- if (axMapControl1.get_Layer(i) is IFeatureLayer)
- {
- //将图层强制转换为IFeatureLayer
- IFeatureLayer pFeatureLayer = axMapControl1.get_Layer(i) as IFeatureLayer;
- //输入目标图层,并转换为IFeatureSelection对象
- IFeatureSelection featureSelection = pFeatureLayer as IFeatureSelection;
- //开始空间查询,查询到的结果保存在ISelectionSet中,可以用游标Cursor来遍历要素
- featureSelection.SelectFeatures((IQueryFilter)spatialFilter, esriSelectionResultEnum.esriSelectionResultNew, false);
- }
- }
- break;
- }
- }
- catch (Exception ex)
- {
- MessageBox.Show("程序执行失败!"+ex);
- }
- }
- #endregion
3.IQueryDef 接口
IQueryDef用于属性查询。它支持复杂的SQL查询并且能在同一工作空间内做连表查询。但是查询后的结果不支持编辑。且不能在Shapefile 和Coverage 数据中使用,而仅仅可以使用在GeoDatabase数据库中。
