实体框架。需要帮助过滤结果

时间:2013-01-25 15:24:01

标签: c# entity-framework filtering

需要在实体框架中选择数据,但需要对子孙和孙子进行过滤

我有4张桌子。 Parent -> Child -> GrandChild -> GreatGrandChild我想要归还所有的父母,但过滤儿童和伟大的孩子。

换言之(例如)

SELECT     Parent.* 
FROM       Parent 
INNER JOIN Child      
INNER JOIN Grandchild 
INNER JOIN GreatGrandChild 
WHERE      child.Column5           =  600   AND
           GreatGrandChild.Column3 = 1000 

它不能是一种不合理的类型,因为我需要更新数据并将saveChanges更新到数据库。

使用vs 2010和EF 4.0

3 个答案:

答案 0 :(得分:2)

使用linq你应该需要这样的东西。

var q = from q1 in dbContext.Parent
        join q2 in dbContext.Children
        on q1.key equals q2.fkey
        join q3 in  ........
        where q4.col1 == 3000
        select q1;

答案 1 :(得分:1)

此查询应该执行您想要的操作。是的,它有点混乱,因为它是如此深层嵌套。

var result = context.Parent
                    .Where(parent => parent.Child
                                           .Any(child => (child.Column5 == 600) &&
                                                          child.GrandChild
                                                               .Any(grandchild => grandchild.GreatGrandChild
                                                                                            .Any(greatgrandchild => greatgrandchild.Column3 == 1000))));

答案 2 :(得分:0)

您的表格结构 - 如果您的示例不仅仅是为了说明,请让我认为您可能想在此处更多地考虑您的模型(即,儿童是独立的实体类型还是应该是定义的关系?)

你所描述的是一个简单的连接和where子句,并且基本上以相同的方式编写:假设你从DBContext返回DBSet:

_context.Parents.Join(context.Child, p=>p.Parent.ID, c=>c.ParentID)
.Join(...Grandchild...).Where(o=>o.Column5=600)
.Join(...GreatGrandChild...).Where(o=>o.Column3=1000)

编辑以取回您可能需要执行以下操作的强类型实体:

var greatgrandchildren = context.GreatGrandchildren.Where(o=>o.Column3=1000).ToList();
var grandchildren = context.Grandchildren.Where(o=>o.Column3=600 and greatgrandchildren.contains(o)).ToList();     
var children = context.Children.Where(o=>grandchildren.Contains(o)).ToList();
var parents = context.Parent(o=>children.Contains(o).ToList();

我的语法可能已关闭,有人可以添加,我可以避免使用.ToList()来阻止往返最后一次调用吗?