CRM不支持直接更新实体引用属性,而是使用导航属性

时间:2016-11-04 00:39:17

标签: dynamics-crm simple.odata simple.odata.client dynamics-crm-webapi

我正在使用Dynamic Web Api和Simple OData。我需要为链接实体添加新记录。

我正在使用以下代码片段并参考文档 https://github.com/object/Simple.OData.Client/wiki/Adding-entries-with-links

       var newContactData = await _oDataClient
            .For<Contacts>()
               .Set(new
               {
                   firstname = contactData.ContatDetails.firstname,
                   lastname = contactData.ContatDetails.lastname,
                   emailaddress1 = contactData.ContatDetails.emailaddress1
               })
               .InsertEntryAsync(true);

        var newContactLink = await  _oDataClient.For<New_project_contactses>()
                .Set(new
                {
                    _new_contact_project_name_new_value = contactData.ContatDetailsLink._new_contact_project_name_new_value,
                    new_project_contactsid = new Guid("0eb46b24-21a2-e611-80eb-c4346bc5b2d4"),
                    new_contact_type = contactData.ContatDetailsLink.new_contact_type,

                })
                .InsertEntryAsync(resultRequired: true);

我正在异常

  

CRM不支持直接更新实体参考属性,使用   导航属性改为

2 个答案:

答案 0 :(得分:7)

嗯,这是可能的,但您需要使用特殊的“@ odata.bind”语法来更新单导航属性。

例如,要更新帐户以便它引用现有的primarycontactid,您可以使用以下正文对/api/data/v8.2/accounts端点进行PATCH操作:

{
   "name":"Sample Account",
   "primarycontactid@odata.bind":"/contacts(00000000-0000-0000-0000-000000000001)"
}

参见https://msdn.microsoft.com/en-us/library/gg328090.aspx#Anchor_3(在创建实体方面进行了讨论,但它也适用于更新)。

答案 1 :(得分:2)

我弄清楚使用Dynamc CRM的问题,您无法直接更新参考实体Field。您可以识别以&#34; _&#34;开头的参考实体属性。