Ошибка получения XML-запроса

В компании, в которой я работаю, я создал новую сущность в Microsoft Dynamics CRM 2013 под названием «Проблема», внутри сущности «Проблема» есть подсетка, в которой пользователи могут добавлять записи из сущности «Стоимость для бизнеса».

Цель состоит в том, чтобы пользователи добавляли записи по мере необходимости. Теперь я использую запрос FetchXML с подключаемым модулем C #, чтобы получить атрибут стоимости, связанный с каждой записью в подсетке, чтобы я мог заполнить поле общей стоимости.

Пока у меня есть следующий запрос

Guid orderID = (Guid)((Entity)context.InputParameters["Target"]).Id;

string fetchxml =
    @"<fetch distinct='true' mapping='logical' output-format='xml-platform' version='1.0'>
          <entity name='new_issue'>
              <attribute name='new_issueid'/>
              <attribute name='new_name'/>
              <attribute name='createdon'/>
              <order descending='false' attribute='new_issueid'/>
              <filter type='and'> 
                  <condition attribute='new_issueid' operator='eq' value='" + orderID + @"'/> 
              </filter> 
              <link-entity name = 'new_costtype' alias='ac' to='new_issueid' from='new_costtypeissueid'>
                  <link-entity name='new_costtobusiness' alias='ad' to='new_costtobusinesscosttypeid' from='new_costtobusinessid'>
                       <attribute name='new_coststring'/>                                             
                  </link-entity>
              </link-entity>
          </entity>
      </fetch>"; 

Однако запрос не может ничего возвращать, так как следующий код не выполняется.

EntityCollection result = service.RetrieveMultiple(new FetchExpression(fetchxml));

if (result != null && result.Entities.Count > 0)
{
    List<int> _product = new List<int>();

    foreach (Entity _entity in result.Entities)//loop through every record
    {
        costToBusiness = ((AliasedValue)_entity.Attributes["ad.new_coststring"]).Value.ToString();
        total = (total) + Convert.ToInt32(costToBusiness);           
    }

    if(entity.Attributes.Contains("new_businessstring"))
    {
        entity.Attributes["new_businessstring"] = currencyName +  total.ToString();
        costToBusiness = "";
        total = 0;
        currencyName = "";
    }
    else
    {
        entity.Attributes.Add("new_businessstring", currencyName +  total.ToString());
        costToBusiness = "";
        total = 0;
        currencyName = "";            
    }
}

Есть ли у кого-нибудь причина / предположение, почему это происходит? заранее спасибо

Обновить

Подробности из загруженного журнала из throw new InvalidPluginExecutionExeption

Unhandled Exception: System.ServiceModel.FaultException`1[[Microsoft.Xrm.Sdk.OrganizationServiceFault, Microsoft.Xrm.Sdk, Version=6.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35]]: <fetch distinct='true' mapping='logical' output-format='xml-platform' version='1.0'>
                    <entity name='new_issue'>
                        <attribute name='new_issueid'/>
                        <attribute name='new_name'/>
                        <attribute name='createdon'/>
                            <order descending='false' attribute='new_issueid'/>
                            <filter type='and'> 
                                <condition attribute='new_issueid' operator='eq' value='ddd33910-7c12-e411-a5f0-00155d550f0a'/> 
                            </filter> 
                            <link-entity name = 'new_costtype' alias='ac' to='new_issueid' from='new_costtypeissueid'>
                            <link-entity name='new_costtobusiness' alias='ad' to='new_costtobusinesscosttypeid' from='new_costtobusinessid'>
                                <attribute name='new_coststring'/>                                             
                            </link-entity>
                            </link-entity>
                    </entity>
              </fetch>Detail: 
<OrganizationServiceFault xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.microsoft.com/xrm/2011/Contracts">
  <ErrorCode>-2147220891</ErrorCode>
  <ErrorDetails xmlns:d2p1="http://schemas.datacontract.org/2004/07/System.Collections.Generic">
<KeyValuePairOfstringanyType>
  <d2p1:key>OperationStatus</d2p1:key>
  <d2p1:value xmlns:d4p1="http://www.w3.org/2001/XMLSchema" i:type="d4p1:string">0</d2p1:value>
</KeyValuePairOfstringanyType>
<KeyValuePairOfstringanyType>
  <d2p1:key>SubErrorCode</d2p1:key>
  <d2p1:value xmlns:d4p1="http://www.w3.org/2001/XMLSchema" i:type="d4p1:string">
2146233088</d2p1:value>
</KeyValuePairOfstringanyType>

`fetch distinct='true' mapping='logical' output-format='xml-platform'version='1.0'&gt;
                    &lt;entity name='new_issue'&gt;
                        &lt;attribute name='new_issueid'/&gt;
                        &lt;attribute name='new_name'/&gt;
                        &lt;attribute name='createdon'/&gt;
                            &lt;order descending='false' attribute='new_issueid'/&gt;
                            &lt;filter type='and'&gt; 
                                &lt;condition attribute='new_issueid' operator='eq' value='ddd33910-7c12-e411-a5f0-00155d550f0a'/&gt; 
                            &lt;/filter&gt; 
                            &lt;link-entity name = 'new_costtype' alias='ac' to='new_issueid' from='new_costtypeissueid'&gt;
                            &lt;link-entity name='new_costtobusiness' alias='ad' to='new_costtobusinesscosttypeid' from='new_costtobusinessid'&gt;
                                &lt;attribute name='new_coststring'/&gt;                                             
                            &lt;/link-entity&gt;
                            &lt;/link-entity&gt;
                    &lt;/entity&gt;
              &lt;/fetch&gt;</Message>
<Timestamp>2014-08-13T13:10:53.9593098Z</Timestamp>

[CostToBusiness: CostToBusiness.CostBusiness]
[2db9e3ba-3616-e411-a5f0-00155d550f0a: CostToBusiness.CostBusiness: Update of new_issue]


</TraceText>
</OrganizationServiceFault>

`

Извините за последнюю часть сообщения, по какой-то причине не могу получить все это в формате кода


person Sjharrison    schedule 12.08.2014    source источник
comment
Нужен дополнительный контекст. Как должен выполняться код? Это в плагине? Как регистрируется плагин?   -  person Daryl    schedule 12.08.2014
comment
Привет @Daryl! Это плагин, и он зарегистрирован при обновлении, перед операцией и синхронно (перед операцией, поскольку плагин обновляет поле) Спасибо   -  person Sjharrison    schedule 13.08.2014
comment
Ожидаете ли вы, что плагин сработает, когда пользователь добавит новую стоимость для бизнеса?   -  person Daryl    schedule 13.08.2014
comment
Нет, плагин не должен срабатывать при сохранении / обновлении записи.   -  person Sjharrison    schedule 13.08.2014
comment
Проблема связана с запросом, поскольку я добавляю исключение throw new InvalidPluginExecutionExeception в свой цикл foreach, который не был вызван, поэтому запрос должен ничего не возвращать обратно   -  person Sjharrison    schedule 13.08.2014
comment
Я бы выбросил исключение, как только вы сгенерируете FetchXml, который выводит FetchXml, просто чтобы быть уверенным, что вы генерируете ожидаемый FetchXml.   -  person Daryl    schedule 13.08.2014
comment
хорошо, поэтому я добавил следующий throw new InvalidPluginExecutionException(fetchxml); сразу после ‹/fetch›, и появившееся окно с ошибкой также было пустым   -  person Sjharrison    schedule 13.08.2014
comment
Есть ли какие-либо сведения об ошибке загрузки?   -  person Daryl    schedule 13.08.2014
comment
Я опубликую загруженные данные журнала как обновление сейчас   -  person Sjharrison    schedule 13.08.2014


Ответы (1)


Если я правильно понимаю, у вас есть new_issue как дочерняя сущность какой-то другой сущности с полем для хранения агрегированных затрат из new_issue. В этом случае у вас должен быть плагин PostOperation (Create / Update / StateChange) для new_issue, и ваш fetch xml должен быть агрегированным fetch xml, который будет искать все new_issue, где идентификатор поля поиска равен идентификатору родительского объекта, а затем агрегировать стоимость. В случае удаления вы должны обработать это немного иначе. HTH

person MaKeer    schedule 15.08.2014
comment
Не могу использовать его как PostOperation, поскольку я использую плагин для обновления поля. Следовательно, это должна быть предварительная проверка / предварительная операция. - person Sjharrison; 19.08.2014