Добро пожаловать в форум, Guest  >>   Войти | Регистрация | Поиск | Правила | В избранное | Подписаться
Все форумы / ADO.NET, LINQ, Entity Framework, NHibernate, DAL, ORM Новый топик    Ответить
 Не удалось сравнить элементы типа  [new]
ughunter
Member

Откуда: Владивосток
Сообщений: 132
Не удалось сравнить элементы типа "System.Collections.Generic.ICollection`1[[Domain.Models.Regulatory, Domain, Version=1.0.0.0, Culture=neutral, PublicKeyToken=fa8ccc6c71b7889b]]". Поддерживаются только типы-примитивы, типы перечисления и типы сущностей.

Есть 2 модели:
public class Regulatory
    {
        public Regulatory()
        {
            Tags = new HashSet<Tag>();
        }

        [Display(Name = "Идентификатор документа")]
        public int Id { get; set; }

        [Display(Name = "Теги")]
        public virtual ICollection<Tag> Tags { get; set; }

    }

public class Tag
    {
        public Tag()
        {
            Articles  = new HashSet<Article>();
            Events  = new HashSet<Event>();
            Regulatories  = new HashSet<Regulatory>();
        }

        [Display(Name = "Идентификатор тега")]
        public int Id { get; set; }

        [Display(Name = "Статьи")]
        public virtual ICollection<Article> Articles { get; set; }

        [Display(Name = "События")]
        public virtual ICollection<Event> Events { get; set; }

        [Display(Name = "Акты")]
        public virtual ICollection<Regulatory> Regulatories { get; set; }

    }


далее делаем так:
var regulatories = Repository
                .AllIncluding((Regulatory reg) => reg.Tags)
                .Where(r => r.Status == DocumentStatus.Published)
                .Where(p => category == null || p.Tags.Any(t => t.Name == category))
                .OrderBy(p => p.Id)
                .ToList();


все нормально. а если так:

var tags = Repository.Tags.Where(t => t.Regulatories != null).ToList();


получаем забавную ошибку (см. выше)
до ToList() они DbSet<T>

такая же ошибка происходит если пробежаться (начать) форычом по тегам - ну тут ясно - в DbSet не реализован интерфейс...

Что и где я делаю не так?
8 окт 15, 10:43    [18251193]     Ответить | Цитировать Сообщить модератору
 Re: Не удалось сравнить элементы типа  [new]
ughunter
Member

Откуда: Владивосток
Сообщений: 132
пардон... не DbSet а {System.Data.Entity.Infrastructure.DbQuery<Domain.Models.Tag>}

запарился
8 окт 15, 10:55    [18251273]     Ответить | Цитировать Сообщить модератору
 Re: Не удалось сравнить элементы типа  [new]
ughunter
Member

Откуда: Владивосток
Сообщений: 132
Разобрался... Если вдруг кому понадобится.
В модели указано ICollection<Regulatory> Regulatories

а здесь мы пытаемся выбрать все теги, которые принадлежат актам var tags = Repository.Tags.Where(t => t.Regulatories != null).ToList(); отношение (*-*)

Ну собственно Entity а ругается ибо тип который сравниваем это объект а не примитив, или перечисление и тем более не сущность. Соответственно не срабатывает ToList()

Решение проблемы крылось в анализе поступающих данных и конечно SQL Server Profiler помог.
Вот решение данной проблемы (без замашек, что эту проблему в другом контексте можно решить также)

var tags = repository.Tags
                .Where(r => r.Regulatories.Count > 0)
                .ToList();


Тема закрыта.
9 окт 15, 07:45    [18256508]     Ответить | Цитировать Сообщить модератору
Все форумы / ADO.NET, LINQ, Entity Framework, NHibernate, DAL, ORM Ответить