首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EF4 CTP5多态查询

EF4 CTP5多态查询
EN

Stack Overflow用户
提问于 2011-01-23 17:03:35
回答 1查看 412关注 0票数 1

我有一个类似如下的模型:

代码语言:javascript
复制
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; }
}

(如果this infrastructure很重要,我会使用它)。

我需要的是让所有不是经理的员工。只有一种OfType扩展方法。我需要的是NotOfType。

代码语言:javascript
复制
    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;

离题:对于这种情况,继承是正确的选择吗?如何对其进行建模?我只是觉得继承把我引向了错误的道路。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-01-29 10:09:22

也许您会发现NotOfType扩展方法应该更好,但这对您来说应该是有效的。

代码语言:javascript
复制
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;

或者像这样:

代码语言:javascript
复制
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;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4773049

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档