|
23.04.2012, 23:54 | #1 |
Участник
|
Получение данных из связанных сущностей
Всем доброго времени суток! Есть 2 сущности, марки автомобилей и их модели. Связаны отношением 1:N. Необходимо получить все модели определенной марки. При выполнении запроса вылезает ошибка, которая говорит, собственно, что произошла ошибка в запросе.
QueryExpression query = new QueryExpression(); query.EntityName = EntityName.Сущность_модель.ToString(); ColumnSet cols1 = new ColumnSet(); cols1.Attributes = new string[] { "Название модели" }; ConditionExpression condition = new ConditionExpression(); condition.AttributeName = "Марка"; condition.Operator = ConditionOperator.Equal; condition.Values = new string[] { "Форд"}; FilterExpression filter = new FilterExpression(); filter.FilterOperator = LogicalOperator.And; filter.Conditions = new ConditionExpression[] {condition }; query.ColumnSet = cols1; query.Criteria = filter; BusinessEntityCollection retrieved = service.RetrieveMultiple(query); foreach (new_model res in retrieved.BusinessEntities) { ....... } Ошибка вылезает вот в этом месте : BusinessEntityCollection retrieved = service.RetrieveMultiple(query); Поле "Марка" имеет тип lookup на сущности модели. Если убрать фильтр, то всё работает, но вытаскивает все модели всех марок. Что интересно, когда ищу марку по названию модели, всё работает как надо, а вот когда наоборот, когда пытаюсь получить модели по марке, то - ошибка описанная выше. Имена сущностей и полей написал на русском языке в запросе, для большей наглядности. CRM 4.0 Заранее спасибо за помощь! Последний раз редактировалось Taker1796; 23.04.2012 в 23:59. |
|
24.04.2012, 00:30 | #2 |
Участник
|
А текст ошибки в Трейсе какой?
|
|
24.04.2012, 00:35 | #3 |
Участник
|
Стоп. А раз это лукап, то Вы должны сюда вставить не название а GUID марки
condition.Values = new string[] { "Форд"}; |
|
24.04.2012, 01:34 | #4 |
Чайный пьяница
|
Цитата:
ЗЫ судя по коду вы используете WebReference от CRM сервисов. По своему опыту - скажу бросайте вы это дело. Советую использовать SDK сборки и DynamicEntity.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством. Подписывайтесь на мой блог, twitter и YouTube канал. Пользуйтесь моим Ultimate Workflow Toolkit |
|
|
За это сообщение автора поблагодарили: Taker1796 (1). |
24.04.2012, 10:11 | #5 |
Участник
|
А можете привести пример кода, чтобы получить GUID определенной марки?
|
|
24.04.2012, 10:33 | #6 |
Участник
|
QueryExpression query = new QueryExpression();
query.EntityName = EntityName.марка.ToString(); ColumnSet cols1 = new ColumnSet(); cols1.Attributes = new string[] { "маркаid" }; ConditionExpression condition = new ConditionExpression(); condition.AttributeName = "Имя марки"; condition.Operator = ConditionOperator.Equal; condition.Values = new string[] { "Форд"}; FilterExpression filter = new FilterExpression(); filter.FilterOperator = LogicalOperator.And; filter.Conditions = new ConditionExpression[] {condition }; query.ColumnSet = cols1; query.Criteria = filter; BusinessEntityCollection retrieved = service.RetrieveMultiple(query); foreach (new_mark res in retrieved.BusinessEntities) { Guid key = new_mark.new_markid; } как то так. Наверное. Я Ваш код переписал. Но разве нельзя в это место передать GUID? Еще можно построить запрос который вернет Вам все машины у которых название марки равно тому, которое Вы хотите. Для этого необзходимо использовать linkedentity. И Еще один самый простой для Вас вариант. Создайте такой запрос в расщиренном поиске. Сохраните его Дальше в таблице UserQuery найдите его. возьмите FetchXML и вызвовите из приложения. Это самый простой вариант как по мне. Минимальное программирование. В расширенном опсике Вы как рас сможете построить запрос такого рода. Дай мне все машины, которые связаны с марками у которых название, и равно тому, которое Вы захотите. В результе Ваш код будет выглядить так. string fetchQuery = ""; // Введите сюда Ваш запрос EntityCollection cars = service.RetrieveMultiple(new FetchExpression(fetchQuery)); Последний раз редактировалось g.Naukovych; 24.04.2012 в 10:40. |
|
|
За это сообщение автора поблагодарили: Taker1796 (1). |
24.04.2012, 10:42 | #7 |
Участник
|
Спасибо!
Кстати, на счет FetchXML, допустим я получил какой то результат в строку. Как из этой строки потом вытащить именно то что я искал, а то строка содержит xml |
|
24.04.2012, 10:55 | #8 |
Участник
|
Цитата:
|
|
|
За это сообщение автора поблагодарили: Taker1796 (1). |
24.04.2012, 11:08 | #9 |
Участник
|
Огромное спасибо всем)
|
|
24.04.2012, 17:29 | #10 |
Участник
|
У меня еще вопрос созрел)
Как получить данные из сущностей, связанных N:N ? Допустим есть Сущность1 и Сущность2. Мне нужно получить данные из Сущность2. Как это реализовать на c#? не используя FetchXML. Желательно кодом написать, а то я новичек в CRM, пока туговато с этим. |
|
24.04.2012, 10:52 | #11 |
Участник
|
Это для crm 2011.
__________________
Читайте SDK!!! |
|
|
За это сообщение автора поблагодарили: Taker1796 (1). |
25.04.2012, 11:43 | #12 |
Участник
|
Если через JavaScript, то crmForm.ObjectId
А как Вы прикрутите C# к форме я не знаю. Трогать страницы сайта нельзя. |
|
25.04.2012, 11:48 | #13 |
Участник
|
|
|
25.04.2012, 12:32 | #14 |
Участник
|
|
|
25.04.2012, 12:42 | #15 |
Участник
|
Думаю, что Вы пишите плагин.
Я на вопрос отвечу, но все же стоит указывать что и для чего, тем более когда у Вас несколько раз спрашивают. Когда у меня была задача узнать ID формы после которой сработал плагин я делал следующее: X++: private string GetParamFromUrl(string url, string param) { if (url == null || url == string.Empty || url == "") return string.Empty; Uri ur = new Uri(url); string[] querySegments = ur.Query.ToLower().Split('&'); string Guid = String.Empty; foreach (string segment in querySegments) { string[] parts = segment.Split('='); if (parts.Length > 0) { string key = parts[0].Trim(new char[] { '?', ' ' }); if (key.ToLower() == param.ToLower()) { Guid = parts[1].Trim(); Guid = Guid.Replace("{", "").Replace("}", "").Replace("%7b", "").Replace("%7d", "").Replace("=", ""); break; } } } return Guid; } string refererUrl = HttpContext.Current.Request.ServerVariables["HTTP_REFERER"]; if (string.IsNullOrEmpty(refererUrl)) return; string filterParam = GetParamFromUrl(refererUrl, "id"); Это очень полезная штука. Я её использую для фильтрации плагинов и для определения откуда именно сработал плагин, Так например у меня была задача при конвертации e-mail и звонка в обращение заполнить поля обращении определенным образом. Вт этот механизм мне здесь пригодился. Непомню почему именно этот, вроде остальные не помогли. Последний раз редактировалось g.Naukovych; 25.04.2012 в 12:47. |
|
25.04.2012, 13:00 | #16 |
Участник
|
Цитата:
Ваш способ, конечно, работает, НО в плагинах CRM существует context, в котором можно найти ID записи на которую бежит плагин. Колличество строчек кода при этом несопоставимо с Вашим. В Post Create, например, это выглядит так: Guid id = (Guid)context.OutputParameters.Properties[ParameterName.Id]; |
|
25.04.2012, 13:12 | #17 |
Участник
|
Я не плагин юзаю. Веб приложение создаю. То есть при переходе на вкладку, грузится страница aspx. И выполняет необходимый запрос на c#. И соответственно необходимо узнавать guid открытой формы.
И вот у меня как раз вопрос по N:N. Мне нужно получить список кредитных программ для определенной модели авто, которые есть. Юзаю код: ColumnSet cols3 = new ColumnSet(); cols3.Attributes = new string[] { "new_name" };//название кредитной программы ConditionExpression condition2 = new ConditionExpression(); condition2.AttributeName = "new_name";// название модели condition2.Operator = ConditionOperator.Equal; condition2.Values = new string[] { "Mustang" }; FilterExpression filter2 = new FilterExpression(); filter2.FilterOperator = LogicalOperator.And; filter2.Conditions = new ConditionExpression[] { condition2 }; LinkEntity link = new LinkEntity(); link.LinkCriteria = filter2; link.LinkFromEntityName = EntityName.new_credit.ToString(); link.LinkFromAttributeName = "new_creditid"; //тип primarykey link.LinkToAttributeName = "new_modelid";//тип primarykey link.LinkToEntityName = EntityName.new_model.ToString(); QueryExpression querry = new QueryExpression(); querry.EntityName = EntityName.new_credit.ToString(); querry.ColumnSet = cols3; querry.LinkEntities = new LinkEntity[] { link }; RetrieveMultipleRequest retr = new RetrieveMultipleRequest(); retr.Query = querry; RetrieveMultipleResponse retr2 = (RetrieveMultipleResponse)service.Execute(retr); В результате запрос ничего не выполняет. То есть retr2 пустой. Не понимаю в чем трабла и что я делаю не так. Ошибок при выполнении нет Последний раз редактировалось Taker1796; 25.04.2012 в 13:20. |
|
25.04.2012, 13:29 | #18 |
Участник
|
При создании iframe попробуйте воспользоваться вот этим
__________________
Читайте SDK!!! |
|
25.04.2012, 13:40 | #19 |
Участник
|
Цитата:
Или у Вас все таки не N:N? Ели N:N, то я Вам переписала код X++: ConditionExpression condition2 = new ConditionExpression(); condition2.AttributeName = "new_name";// название модели condition2.Operator = ConditionOperator.Equal; condition2.Values = new string[] { "Mustang" }; FilterExpression filter2 = new FilterExpression(); filter2.FilterOperator = LogicalOperator.And; filter2.AddCondition(condition2); LinkEntity link2 = new LinkEntity(); link2.LinkFromEntityName = EntityName.new_credit.ToString(); link2.LinkFromAttributeName = "new_creditid"; //тип primarykey link2.LinkToAttributeName = "new_creditid";//тип primarykey link2.LinkToEntityName = ["Name of Relationship N:N"]; LinkEntity link = new LinkEntity(); link.LinkCriteria = filter2; link.LinkFromEntityName = ["Name of Relationship N:N"]; link.LinkFromAttributeName = "new_modelid"; //тип primarykey link.LinkToAttributeName = "new_modelid";//тип primarykey link.LinkToEntityName = EntityName.new_model.ToString(); link2.LinkEntities = new LinkEntity[]{link}; QueryExpression querry = new QueryExpression(); querry.EntityName = EntityName.new_credit.ToString(); querry.ColumnSet = cols3; querry.LinkEntities = new LinkEntity[] { link2}; RetrieveMultipleRequest retr = new RetrieveMultipleRequest(); retr.Query = querry; RetrieveMultipleResponse retr2 = (RetrieveMultipleResponse)service.Execute(retr); Последний раз редактировалось Ksani; 25.04.2012 в 14:00. |
|
25.04.2012, 14:22 | #20 |
Участник
|
Ksani, спасибо большое! Я твой должник! Ты супер!)
|
|
|
Опции темы | Поиск в этой теме |
Опции просмотра | |
|