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

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
  • URLをコピーしました!

この記事を書いた人

伊達と酔狂のGeospatial Communicator。GIS上級技術者、Esri認定インストラクター、CompTIA CTT+ Classroom Trainer、潜水士、PADIダイブマスター、四アマ。WordPress は 2.1 からのユーザーで歴だけは長い。代表著書に『"地図リテラシー入門―地図の正しい読み方・描き方がわかる』。日本地理学会賞(著作発信部門)受賞(2024年)。好きな地図投影法はパース・クインカンシャル図法とマクブライド・トーマス平極四次曲線図法。発言は個人の見解です。

ESRIジャパン株式会社所属、日本地図学会常任委員、青山学院大学非常勤講師兼務(2021年度~2023年度)、ストーリーマップ自己紹介、researchmapポートフォリオ

目次