问题描述:
pFeatCursor = pFeatCls.Search(pQueryFilter, true);出现如下错误提示:
未处理 System.Runtime.InteropServices.COMException
Message="每用户订阅上的所有人 SID 不存在 (异常来自 HRESULT:0x80040207)"
处理方案:
出现这个异常只要是因为过滤器的WhereClause语句不规范导致的,解决方案:
为字段名添加引号修饰符,"fieldName"
为字段的值添加单引号修饰符,"20010200LL00BS"
修改后的查询语句为: "\"fieldName\" = '20010200LL00BS'"
修正之后的代码如下:
private void btnOk_Click(object sender, EventArgs e) { //定义图层,要素游标,查询过滤器,要素 IFeatureLayer pFeatureLayer = this.axMapControl1.Map.get_Layer(cboLayer.SelectedIndex ) as IFeatureLayer; IFeatureClass pFeatureClass = pFeatureLayer.FeatureClass; string strFldName = pFeatureClass.Fields.get_Field(cboField.SelectedIndex).Name; IQueryFilter pQueryFilter = new QueryFilterClass(); pQueryFilter.WhereClause = "strFldName='" + txtStateName.Text + "'"; IFeatureCursor pFeatureCursor = pFeatureLayer.Search(pQueryFilter, true); IFeature pFeature = pFeatureCursor.NextFeature(); }
拓展知识:
检查发现是QueryFilter.WhereClause语句在查询shapefile格式的图层出现了问题,试验在查询gdb格式的图层不会报错。打开ArcGIS比较了两种格式的属性查询存在以下的区别:
shapefile的字段名用双引号如:"fieldName"而GDB的采用[fieldName]格式;
shapefile的模糊查询用like '%A%' 而GDB用like '*A*' ;
shapefile的非字符字段不支持模糊查询而GDB格式的支持;不过我记得9.2的时候好像支持^_^。
所以在查询前必须判断一下图层的数据源类型:
if (pDateset.Workspace.Type == esriWorkspaceType.esriFileSystemWorkspace) { pQueryFilter.WhereClause = "\"" + fldName + "\"" + " like '%" + this.txt_findObject.Text.Trim() + "%'"; //shpfile } else { pQueryFilter.WhereClause = "[" + fldName + "]" + " like '*" + this.txt_findObject.Text.Trim() + "*'"; //gdb }