请假设架构:
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/