在使用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,数值会自动添加上。添加完成,再执行程序就可以执行了。

本文介绍了解决在使用AO组件开发SOE过程中遇到的问题,即在SDE中对无空间信息的普通表进行更新操作时发生的错误。通过将属性表注册到数据库并自动添加OBJECTID列的方法成功解决了此问题。
1662

被折叠的 条评论
为什么被折叠?



