arcgis二次开发 arcengine属性表连接join
看了好多资源,现在总结一下我的属性链接功能实现。
首先这种方法的基表必须是要素图层,.dbf表是不可能作为基表进行连接的(或许可以但我没实现),而外表可以是要素图层的属性表,同时也可以是.dbf表。方法中的字符串参数就是属性连接时的挂接字段。
首先要进行属性挂接,必须能够访问进行属性挂接的成员,IDisplayRelationshipClass接口提供了这种功能,而这个成员就是我们进行属性挂接的要素图层IDisplayRelationshipClass pDisplayRelationshipC = f as IDisplayRelationshipClass;
明确了这个建立属性连接的成员之后,下一步就开始进行属性挂接,IDisplayRelationshipClass接口的DisplayRelationshipClass(IRelationshipClass relClass, esriJoinType JoinType);方法就实现了这个属性挂接功能;而这个方法中的参数呢,我们继续分析。首先是IRelationshipClass relClass,IRelationshipClass接口提供访问返回连接类、创建连接关系、连接规则以及相关对象的成员,那么这些相关信息如何获取呢,IMemoryRelationshipClassFactory接口的 Open(string Name, IObjectClass originPrimaryClass, string originPrimaryKeyField, IObjectClass originForeignClass, string originForeignKeyField, string ForwardPathLabel, string BackwardPathLabel, esriRelCardinality Cardinality)方法恰好可以提供这些信息。首先定义一个IMemoryRelationshipClassFactory接口pMemRelClassFactory,令他指向实例化类MemoryRelationshipClassFactoryClass(),然后定义一个IRelationshipClass pRelaClass,令他指向pMemRelClassFactory的open()方法,而这个方法中的参数很简单,参数一:给连接起个名字,参数二:基表,参数三:基表挂接字段,参数四:外表,参数五:外部挂接字段,参数六、七向前向后路径标签:随便起,参数八:连接属性的关系,包括一对一、一对多、多对多,一般来讲都是选择一对一。所有参数设置完就可以实现属性表连接了,
这个方法不适用于.dbf表之间的连接,.dbf表之间的连接下次再说。
using ESRI.ArcGIS.Geodatabase;
using ESRI.ArcGIS.Carto;
public IFeatureClass Join(ILayer e1, ITable e2, string f1, string f2)
{
IFeatureLayer f = e1 as IFeatureLayer;
IFeatureClass ifc = f.FeatureClass;
//join
IMemoryRelationshipClassFactory pMemRelClassFactory = new MemoryRelationshipClassFactoryClass();
IRelationshipClass pRelaClass = pMemRelClassFactory.Open("JOIN", (IObjectClass)e1, f1, (IObjectClass)e2, f2, "forward", "backward", esriRelCardinality.esriRelCardinalityOneToOne);
IDisplayRelationshipClass pDisplayRelationshipC = f as IDisplayRelationshipClass;
pDisplayRelationshipC.DisplayRelationshipClass(pRelaClass, esriJoinType.esriLeftInnerJoin);
IDisplayTable displaytable = pDisplayRelationshipC as IDisplayTable;
IFeatureClass outf = displaytable.DisplayTable as IFeatureClass;
return outf;
}