EF条件包含(按实体类型) [英] EF Conditional Include by Entity Type

查看:46
本文介绍了EF条件包含(按实体类型)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

请假设架构:

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的链接。

这篇关于EF条件包含(按实体类型)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆