首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EF code-first:如何加载相关数据(父-子-孙)?

EF code-first:如何加载相关数据(父-子-孙)?
EN

Stack Overflow用户
提问于 2011-09-22 08:28:13
回答 2查看 12.3K关注 0票数 7

我有这个实体:

代码语言:javascript
复制
public class DynamicPage {

    public int PageId { get; set; }

    public int Order { get; set; }

    public string MenuText { get; set; }

    public string MenuHover { get; set; }

    public int? ParentId { get; set; }

    public virtual DynamicPage Parent { get; set; }

    public virtual ICollection<DynamicPage> Children { get; set; }
}

该实体可以具有3个级别:父实体、子实体、孙子实体、子实体、孙子实体、->孙子实体、->孙子实体如何加载具有所有关联子项(级别2)的父项(级别1),以及对于每个子项,关联的子项(级别3) (如果有)?感谢你的帮助。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-09-23 01:39:50

EF 4.1功能和语法:

代码语言:javascript
复制
var entity = context.Parents
    .Include(p => p.Children.Select(c => c.GrandChildren))
    .FirstOrDefault(p => p.Id == 1); // or whatever condition
票数 12
EN

Stack Overflow用户

发布于 2011-09-22 08:51:28

如果您想让自己的生活更轻松,请遵循EF Code First约定,将您的表If简单命名为Id (或者,表名+ Id,例如DyanmicPageId)。

这应该会给你留下类似这样的结果:

代码语言:javascript
复制
public class DynamicPage
{
    public int Id { get; set; }
    public int Order { get; set; }
    public string MenuText { get; set; }
    public string MenuHover { get; set; }
    public int? ParentId { get; set; }

    public virtual DynamicPage Parent { get; set; }
    public virtual ICollection<DynamicPage> Children { get; set; }
}

然后,需要在DbContext类的OnModelCreating方法中显式设置父对象和子对象之间的关系。

代码语言:javascript
复制
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<DynamicPage>()
        .HasMany(page => page.Children)
        .WithRequired(child => child.Parent)
        .HasForeignKey(child => child.ParentId);
}

然后,您可以根据需要选择子项或孙项:

代码语言:javascript
复制
var parent = dbContext.DynamicPages.Where(page => page.ParentId == null);
var children = parent.Children;
var grandchildren = parent.SelectMany(page => page.Children);
var allRelatedPages = parent.Union(children).Union(grandchildren);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7508241

复制
相关文章

相似问题

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