gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 19:47:46 24 4
gpt4 key购买 nike

请假设架构:

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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com