首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Linq多级内连接

Linq多级内连接
EN

Stack Overflow用户
提问于 2016-04-12 07:06:12
回答 1查看 103关注 0票数 1

我有三个不同的实体:

E1, E2, E3

E1具有一个属性,即ObservableCollection of E2。E2具有一个属性,即ObservableCollection of E3。

使用linq查询,我希望获得所有基于我获得的E3作为起点的E1。

我试过这样的方法:

代码语言:javascript
复制
Query = Query.Where<E3>(i => E1.E2List.Select(ep => ep.E3List.Select(ai => ai.id))
             .Contains(i.id));

基本意思是:从E3获得id所在的所有E3列表中的E2列表中的E1

但正如你猜的,这不管用。

代码语言:javascript
复制
My starting point is this :
//make the array 
E3[] array;
//get all E3 datas
IQueryable<E3> Query = DBSetE3.AsQueryable();

我必须在我的数组中得到所有的结果

因此,我的结果应该是:进入数组,所有链接到E3中的E2对象都包含在E1中,基于E1。

例如:

代码语言:javascript
复制
Entity 1| List of E2
E1 | E2A, E2B

Entity 2 | List of E3
E2B | E3C, E3D
E2A | E3E, E3F

当我搜索链接到E3的E1时,我必须找到E3C,E3D,E3E,E3F

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-04-12 07:12:56

你可以这样做:

代码语言:javascript
复制
var e1Ids = new [] { 1, 2, 3 };
var e3s = DBSetE1.AsQueryable().Where(e => e1Ids.Contains(e.Id))
                               .SelectMany(e => e.E2List)
                               .SelectMany(e => e.E3List);

基本上,你根据输入过滤所有E1。然后,您需要SelectMany (将结果[[1,2],[3,4]]压缩为[1,2,3,4])来获取E2s。那你SelectMany我是E3s。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36565932

复制
相关文章

相似问题

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