需要在实体框架中选择数据,但需要对子孙和孙子进行过滤
我有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
答案 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()来阻止往返最后一次调用吗?