AXForum  
Вернуться   AXForum > Microsoft Dynamics CRM > Dynamics CRM: Разработка
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 09.07.2009, 20:40   #1  
alsherin is offline
alsherin
Участник
 
62 / 11 (1) +
Регистрация: 23.06.2009
? Преобразование Key->Guid
Для получения выборки ссылочной сущности (отношение 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" и пришлось искать способ привести значения к нужному типу.
Старый 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
Старый 10.07.2009, 13:38   #3  
Tony Green is offline
Tony Green
Участник
Аватар для Tony Green
 
184 / 25 (1) +++
Регистрация: 08.10.2002
Адрес: Москва
Вот такая штука возвращает GUID:
Код:
((Key)DynamicEntity.Properties["new_primaryobjectid"]).Value
__________________
С уважением,
Tony Green
За это сообщение автора поблагодарили: alsherin (1).
Старый 10.07.2009, 15:21   #4  
alsherin is offline
alsherin
Участник
 
62 / 11 (1) +
Регистрация: 23.06.2009
С точки зрения производительности какой код эффективнее? Можно ли было сразу написать:

Код:
ce.Values[i] = ((Key)((DynamicEntity)result.BusinessEntityCollection.BusinessEntities[i]).Properties["new_primaryobjectid"]).Value;
Какое количество inline преобразований допустимо/разумно?
Старый 10.07.2009, 15:25   #5  
Артем Enot Грунин is offline
Артем Enot Грунин
Moderator
Аватар для Артем Enot Грунин
MCBMSS
Злыдни
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,912 / 623 (28) +++++++
Регистрация: 16.08.2007
Адрес: Пермь!
Записей в блоге: 151
Не важно. Компилятор все равно оптимизирует код за вас. Пишите так, как удобно отлаживать и вносить изменения.
__________________
http://fixrm.wordpress.com, снятие/наведение порчи. Быстро, дорого, гарантия.

MS Certified Dirty Magic Professional
За это сообщение автора поблагодарили: alsherin (1).
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
tekoppele: Longer Support Timelines for Key Microsoft Dynamics Service Packs Blog bot Dynamics CRM: Blogs 0 25.06.2009 14:05
Jim Wang: CRM 4.0 Get attribute value from entity's GUID using JScript Blog bot Dynamics CRM: Blogs 0 11.02.2009 06:05
Мир CRM: The key specified to compute a hash value is expired, only active keys are valid Blog bot Dynamics CRM: Blogs 0 30.07.2008 20:05
Обновление CRM 1.2->3.0->4.0 maxim_ufa Dynamics CRM: Администрирование 8 24.07.2008 13:39
Определение GUID родительской сушъности faust911 Dynamics CRM: Разработка 4 12.07.2006 08:59
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 23:24.