首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >检索相关数据(多层次)

检索相关数据(多层次)
EN

Stack Overflow用户
提问于 2016-12-09 02:04:18
回答 1查看 62关注 0票数 0

我有三门课:

  1. Country.
  2. .
  3. 公共类国家{公共国家(){区域=新的HashSet();}公共字符串名称{ get;set;}公共虚拟ICollection区域{ get;私有集;}公共类同上{公共同上(){各省=新HashSet();}公共字符串名称{ get;set;}公共虚拟ICollection省份{ get;私有set;}公共类省{公共字符串名称{ get;set;}公共类省{公共字符串名称{get;set;}}

我需要完成的是如何在一个使用Ling的命令中包含所有的省()、 all (即使没有)、Country (即使没有地区E 223)。

原因是我要使用DevExpress网格,这样用户就可以看到Country并添加一个新的区,并且可以看到区并添加一个新的省。

我所有的尝试都失败了,因为我得到的是Country,它有Disctrict,区有省。

顺便说一下,我用的是:

  • 与2015年相比
  • EF芯
  • SQL 2016

溶液

经过多次尝试和搜索,我发现我需要使用.ThenInclude到第三级省。比如:

代码语言:javascript
复制
Countries = dbContext
                .Countries
                .Include(c => c.Districts)
                .ThenInclude(p => p.Provinces)
                .ToList();
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-09 02:19:17

如果你能把你试过的东西寄给我们,那就太好了。粗略地说,您可以使用Include来急切地加载依赖于实体和集合。如果您查询从Country开始的实体链,它将检索所有国家,即使它们没有District

代码语言:javascript
复制
using (var dbContext = new YourDbContext())
{
    return dbContext.Countries
        .Include(c => c.Districts.Select(d => d.Provinces))
        .ToList();
}

我想,只有在国家有区域等情况下才能检索它们的原因,是因为您的查询是从链的另一端(Province)开始的,而不是从上面的Country开始的。

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

https://stackoverflow.com/questions/41052011

复制
相关文章

相似问题

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