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

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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值