SOE开发过程中,SDE中的属性表无法用游标更新的问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Sdnu08gis/article/details/80413476

在使用AO组件开发SOE过程中,存在于SDE中的属性表(没有空间信息的表,普通表),在使用ITable接口的update游标时,执行删选时报错,如下图所示:

ITable pTable = pFeatureWorkspace.OpenTable("TableName");  //TableName为属性表名称
IQueryFilter pFilter = new QueryFilterClass();
pFilter.WhereClause = "ID = '" + id + "'";                 //id为传入的变量
ICursor pCursor = pTable.Update(pFilter, false);           //执行到此处,程序报错
IRow pRow = pCursor.NextRow();
while (pRow != null)
{
    ......
}


解决方案:

      将属性表注册到数据库。

步骤:打开sde数据库连接,找到要更新的属性表,右击选择注册到数据库。

      将属性表注册到数据库后,sde会自动在属性表中添加一列OBJECTID,数值会自动添加上。添加完成,再执行程序就可以执行了。


猜你喜欢

转载自blog.csdn.net/Sdnu08gis/article/details/80413476