【发布时间】:2019-01-17 21:03:39
【问题描述】:
所以我正在尝试使用 EF Linq 检索某些实体的(一个或多个)子级。 奇怪的是这不起作用:
public static class DbSetExtension
{
public static IQueryable<T> Include<T>(this IDbSet<T> dbSet, params string[] paths) where T : class
{
foreach (var path in paths)
dbSet.Include(path: path);
return dbSet;
}
}
//Usage: dbSet<Company>().Include(paths: nameof(Company.Projects))
在这种情况下,每个孩子都是空的...... 但是当我使用它时,它可以工作:
dbSet.Include("Projects");
有人知道为什么吗?我能做些什么来解决这个问题?
解决方案
public static IQueryable<T> Include<T>(this IQueryable<T> queryable, params string[] paths) where T : class
{
foreach (var path in paths)
queryable = queryable.Include(path: path);
return queryable;
}
【问题讨论】:
-
也许 dbSet = dbSet.Include("Projects");能行得通?因为你返回一个 DbSet
标签: c# entity-framework linq include