YouTube | Facebook | Twitter  Feed

テーブル結合した結合先のレコードを取得

2016/9/1 (木)

Sub GetRelatedRecord()
    Dim pMxDoc As IMxDocument
    Set pMxDoc = ThisDocument
     
    Dim pFeatureLayer As IFeatureLayer
    Set pFeatureLayer = pMxDoc.FocusMap.Layer(0)    '最上位レイヤを取得
     
    Dim pFeatureClass As IFeatureClass
    Set pFeatureClass = pFeatureLayer.FeatureClass
     
    Dim pDisplayRelationshipClass As IDisplayRelationshipClass
    Set pDisplayRelationshipClass = pFeatureLayer
     
    Dim pRelationshipClass As IRelationshipClass
    Set pRelationshipClass = pDisplayRelationshipClass.RelationshipClass    'テーブル結合されている
     
    Dim pFeature As IFeature
    Set pFeature = pFeatureClass.GetFeature(1)      'OID:1のフィーチャを取得
     
    Dim pObjSet As ISet
    Set pObjSet = pRelationshipClass.GetObjectsRelatedToObject(pFeature)    '元のフィーチャを引数としてリレーション先のフィーチャ群を取得
     
    pObjSet.Reset
     
    Dim pRelFeature As IRow
    Set pRelFeature = pObjSet.Next      'リレーション先のレコードを取得(結合先がフィーチャの場合はIFeatureでキャスト可能)
     
    Debug.Print "Count", pObjSet.Count
    Debug.Print pRelFeature.OID
 
End Sub

関連記事

  • この記事を書いた人

羽田 康祐

Esri認定インストラクター、GIS上級技術者、測量士補、潜水士。GISy / GISc とその関連分野である地理学・地図学について日々の出来事で学んだ記憶を記録するためにブログを書いています。行動原理は伊達と酔狂。好きな地形は圏谷。好きな地図投影法はパースクインカンシャル図法。呉市生まれ広島市出身。GIS を使った自己紹介はこちら

-プログラミング, ArcGIS

© 2020 WINGFIELD since1981