检索包含所有属性的CRM实体时,在某些情况下,某些类型为EntityReference
的属性没有名称。在这种情况下,引用的ID
已设置,但其Name
属性为null
。
我必须使用该名称进行一些评估。因此,我试图查询引用的实体以获取其名称。问题是,包含实体名称的属性因不同的实体类型而不同。
(例如,对于Account它的“名称”,对于Incident它是“title”而对于其他类型它是“somePrefix_name_or_so”)
使用CRM-SDK和查询是否有一种简单的方法来获取实体名称(实体引用的Name属性)?
其他细节: 代码位于CRM插件中。在那里,前/后图像通常包含所有属性,但在某些情况下,在更新期间,(几乎)所有实体引用都会丢失其名称。字典中的属性仍然存在,包括EntityReference对象。只有EntityReference实例的Name属性为null。
到目前为止我的方法:
null
,请执行查询以获取该名称(帮助!如何?)答案 0 :(得分:5)
为此,您需要拥有EntityReference实体的EntityMetadata。然后您可以获取EntityMetadata.PrimaryNameAttribute属性,它包含主名称属性的名称。鉴于该属性名称,您可以获得所需的内容。 在此处查看有关此属性的更多信息:http://msdn.microsoft.com/en-us/library/microsoft.xrm.sdk.metadata.entitymetadata.primarynameattribute.aspx