如何在EF中包含2个导航属性

本文关键字:2个 导航 属性 包含 EF | 更新日期: 2023-09-27 18:28:15

我的数据库中的一个对象有两个导航属性(B和C):

Object A
{
  B bProperty
  C cProperty
}

我希望在查询对象A时同时包含它们。我试着做以下事情:

dbcontext.A.Include(x => x.B).ToList();

但是我怎么也包括C呢?

如何在EF中包含2个导航属性

试试这个

dbcontext.A.Include(x=>x.B).Include(x=>x.C).ToList();

我一次完成所有这些,所以在我的EF存储库类中,我有一个名为GetAllInclude的方法,它等于为每个实体以通用的方式完成,

public IQueryable<T> GetAllIncluding(params Expression<Func<T, object>>[] includes)
{
    var query = DbSet.AsNoTracking();
    query = includes.Aggregate(query, (current, includeProperty) => current.Include(includeProperty));
    return query;
}

其中DbSet是IDbSet类型的私有成员,T是BaseEntity类型的成员。

我使用它的方式就像这个

   MyGenericRepository<A>().GetAllIncluding(x=> x.B, x=> x.C).FirstOrDefault();

希望能有所帮助。