欢迎您来到GIS动力

加入收藏 免费注册 用户登陆 帮助中心
首页 新闻动态 技术专栏 银杏树下 学习考研 软件下载 求职招聘 许愿瓶 节日祝福 用户中心 精彩推荐 资源搜索 地图
专栏导航: AO开发 | SO开发 | ArcGIS桌面 | 超图桌面 | 开发语言 | 数据库 | WebGIS | 银杏文学 | 研究生考题 | FreeMap 谈天说地
   您现在位于: 首页技术专栏ArcGIS应用与开发AO开发 → 正文
ITableSort与Update的效率问题
07-11-20 08:52:47 作者:zdq 出处:zdq.gissky.net

使用ITableSort可以对表进行排序,但是排序後如果用Row.Store()更新记录会非常慢。比较好的办法是先遍历排序表获得一个HashTable,然后从表通过Update方法获得一个可更新的ICursor,然后使用UpdateRow和Flush来更新。速度快很多。片段代码如下:

      '提高效率的办法,不用.Store,首先获得一个OID,和顺序编号的HashTable
      Dim IDHash As New Hashtable
      Do While Not pRow Is Nothing
        ' Debug.Print(pRow.Value(XIndex) & " , " & pRow.Value(YIndex))
        IDHash.Add(pRow.OID, ID)
        ID += 1
        ' pRow.Store()
        pRow = pCursor.NextRow
      Loop

      '然后更新!!
      Dim UpdateCursor As ICursor = pTableSort.Table.Update(Nothing, False)
      pRow = UpdateCursor.NextRow
      Do Until pRow Is Nothing
        If XOffset <> 0 Then pRow.Value(XIndex) = pRow.Value(XIndex) + XOffset
        If YOffset <> 0 Then pRow.Value(YIndex) = pRow.Value(YIndex) + YOffset
        MaxCol = Math.Max(MaxCol, pRow.Value(XIndex))
        MaxRow = Math.Max(MaxRow, pRow.Value(YIndex))
        pRow.Value(WASPIDIndex) = IDHash(pRow.OID)
        UpdateCursor.UpdateRow(pRow)
        pRow = UpdateCursor.NextRow
      Loop
      UpdateCursor.Flush()


(本文已被浏览 次)
发布人:admin
推荐给好友:发送给好友
上篇新闻:
下篇新闻:
相关评论
发表我的评论
  • 尊重网上道德,遵守《全国人大常委会关于维护互联网安全的决定》及中华人民共和国其他各项有关法律法;
  • 本站有权保留或删除您发表的任何评论内容;
  •   相关文章  

    关于我们 友情链接 ┋ 与我在线 ┋ 管理 ┋ TOP
    网站当前版本:GisPower CMS V3.0
    『GIS 动力』- http://www.gispower.org/
    联系我们:webmaster#gispower.org
    Copyright (c) 2003-2007 GisPOwer.Org. All Rights Reserved.

                   滇ICP备05006901号