Показать сообщение отдельно
Старый 09.07.2009, 21:54   #2  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от alsherin Посмотреть сообщение
Для получения выборки ссылочной сущности (отношение N:1) по списку Id основной сущности в запрос нужно передавать эти Id в виде Guid-ов. Guid-ы извлекаются из выборки записей основной сущности, где они содержаться в атрибуте первичного ключа (PK). Это атрибут имеет тип Microsoft.Crm.Sdk.Key и напрямую в Guid никак не хочет преобразовываться. Пришлось применитть 2-х шаговое преобразование с использованием промежуточных переменных:

Код:
ce = new ConditionExpression();
ce.AttributeName = "new_primaryobjectreference";
ce.Operator = ConditionOperator.In;
ce.Values = new Object[result.BusinessEntityCollection.BusinessEntities.Count];
Key dekey;
Guid deid = new Guid();

for (int i = 0; i < result.BusinessEntityCollection.BusinessEntities.Count; i++)
{
   de = (DynamicEntity)result.BusinessEntityCollection.BusinessEntities[i];
   dekey = de.Properties["new_primaryobjectid"] as Key;
   deid = dekey.Value;
   ce.Values[i] = deid;
}
Решение не самое элегантное, но иначе мне никак не удавалось произвести необходимое преобразование - все время вылетала ошибка. Ким еще образом можно (или нужно) это сделать?

В начале я вообще не думал, что нужно будет делать какие-либо преобразования. Для передачи значений создал универсальный массив generic-объектов, в который просто сохранял список ключей. Но при выполении запроса CRM ругался: "ты подсунул Key туда где нужен Guid" и пришлось искать способ привести значения к нужному типу.
Нормально написано.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit