EF4 CTP5 полиморфный запрос - PullRequest
1 голос
/ 23 января 2011

У меня есть модель, подобная следующей:

public class Employee
{
    public Employee()
    {
        TimeCards = new List<TimeCard>();
    }
    public int Id { get; set; }
    public string Name { get; set; }
    public DateTime HireDate { get; set; }
    public virtual ICollection<TimeCard> TimeCards { get; set; }
}
public class Manager : Employee
{
    public bool HasCompanyCar { get; set; }
}
public class Developer : Employee
{
    public string MainProgrammingLanguage { get; set; }
}

(я использую эту инфраструктуру , если это важно).

Что мне нужно, так это собрать всех сотрудников, которые не являются менеджерами. Существует только метод расширения OfType. Что мне нужно, так это NotOfType.

    var employees = unitOfWork.Employees
                   .FindAll()
                   .NotOfType<Manager>(); //or something similar
    var cards = unitOfWork.TimeCards.FindAll();

    var query = from e in employees
                from tc in cards
                where tc.Employee.Id == e.Id && e.Name.StartsWith("C")
                select tc;

Не по теме: является ли наследство правильным выбором для такого рода ситуаций? Как вы моделируете это? Я просто чувствую, что наследство ведет меня по неверному пути.

1 Ответ

0 голосов
/ 29 января 2011

Возможно, вы обнаружите, что метод расширения NotOfType должен быть лучше, но это должно работать для вас.

var employees = unitOfWork.Employees
               .Where(e => !(e is Manager));

var cards = unitOfWork.TimeCards.FindAll();

var query = from e in employees
            from tc in cards
            where 
               tc.Employee.Id == e.Id && 
               e.Name.StartsWith("C")                   
            select tc;

Или вот так:

var employees = unitOfWork.Employees
               .FindAll();

var cards = unitOfWork.TimeCards.FindAll();

var query = from e in employees
            from tc in cards
            where 
               tc.Employee.Id == e.Id && 
               !(e is Manager) &&
               e.Name.StartsWith("C")                   
            select tc;
...