基于C#的ArcEngine二次开发57:每用户订阅上的所有人SID 不存在

简介: 基于C#的ArcEngine二次开发57:每用户订阅上的所有人SID 不存在

问题描述:


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
}
相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
12月前
|
C#
CAD2015 C#二次开发 字体变形
CAD2015 C#二次开发 字体变形
基于C#的ArcEngine二次开发56:双击属性表跳转目标要素并闪烁
基于C#的ArcEngine二次开发56:双击属性表跳转目标要素并闪烁
基于C#的ArcEngine二次开发56:双击属性表跳转目标要素并闪烁
基于C#的ArcEngine二次开发54:IStatusBar状态栏接口的使用
基于C#的ArcEngine二次开发54:IStatusBar状态栏接口的使用
基于C#的ArcEngine二次开发54:IStatusBar状态栏接口的使用
|
NoSQL 数据处理 C#
基于C#的ArcEngine二次开发52:GDB数据处理过程中与Name相关的操作
基于C#的ArcEngine二次开发52:GDB数据处理过程中与Name相关的操作
基于C#的ArcEngine二次开发52:GDB数据处理过程中与Name相关的操作
基于C#的ArcEngine二次开发51:获取图层字段唯一值列表(Get Unique Values)
基于C#的ArcEngine二次开发51:获取图层字段唯一值列表(Get Unique Values)
基于C#的ArcEngine二次开发51:获取图层字段唯一值列表(Get Unique Values)
|
算法 C#
基于C#的ArcEngine二次开发50:生成面空洞连接线
基于C#的ArcEngine二次开发50:生成面空洞连接线
基于C#的ArcEngine二次开发50:生成面空洞连接线
|
存储 NoSQL Unix
基于C#的ArcEngine二次开发50:MDB创建新要素类及“无当前记录”异常处理
基于C#的ArcEngine二次开发50:MDB创建新要素类及“无当前记录”异常处理
基于C#的ArcEngine二次开发50:MDB创建新要素类及“无当前记录”异常处理
|
定位技术 C# 图形学
基于C#的ArcEngine二次开发53: mxd与IPagelayout
基于C#的ArcEngine二次开发53: mxd与IPagelayout
|
NoSQL C# 数据库管理
基于C#的ArcEngine二次开发49:修改图层名称和别名、字段名称
基于C#的ArcEngine二次开发49:修改图层名称和别名、字段名称
基于C#的ArcEngine二次开发48:点是否落在实体上检查
基于C#的ArcEngine二次开发48:点是否落在实体上检查