c# - 实体类型的 EF 条件包含

标签 c# entity-framework entity-framework-6

请假设架构:

public class Mammal
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Dog : Mammal
{
    public int TailId { get; set; }
    public Tail Tail { get; set; }
}

public class Bat : Mammal
{
    public int WingId { get; set; }
    public Wing Wing { get; set; }
}

public class Buffalo : Mammal
{
    public virtual ICollection<Horn> Horns { get; set; }
}

public class Tail
{
    public int Id { get; set; }
    ...
}

public class Wing
{
    public int Id { get; set; }
    ...
}

public class Horn
{
    public int Id { get; set; }
    ...
}

现在,我的上下文:

public class MyContext : DbContext
{
    public DbSet<Mammal> Mammals { get; set; }
}

所以,我只想进行一个 sql 查询,并包含(并加载)所有嵌套实体,例如:

var query = myContext.Mammals
    .IncludeIfTypeIs<Dog>(d => d.Tail)
    .IncludeIfTypeIs<Bat>(b => b.Wing)
    .IncludeIfTypeIs<Buffalo>(b => b.Horns)
    ...
    ...
;

我知道我可以单独执行此操作,但我不想这样做,因为我有很多实体,而且我需要尽量减少数据库请求。

我不想使用延迟加载,因为这也会产生很多数据库请求。

如何实现?

最佳答案

EF Core 在 2.1 及更高版本中支持此功能。查看 Github 问题 here

var query = myContext.Mammals
    .Include(d => (d as Dog).Tail)
    .Include(b => (b as Bat).Wing)
    .Include(b => (b as Buffalo).Horns)

这将在一个查询中包含所有属性。

这是 official documentation 的链接对此。

关于c# - 实体类型的 EF 条件包含,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34019818/

相关文章:

c# - 编辑安装程序类中的自定义配置部分

c# - 调试异步等待 Controller 操作

c# - iTextSharp - 如何打开/读取/提取文件附件?

c# - 在 C# 中处理数据库混淆

asp.net-mvc - 可访问性不一致 : property type in DbContext

c# - 插入迁移

database - 网站和数据库 View

c# - 使用 Entity Framework 从 SQL 数据库中获取除 SQL 之外的所有内容

c# - 如何在循环中链接多个 DbSet.Include()?

database - 在 Code First 中包含外键 ID 以保存查询?