【发布时间】:2015-07-15 12:39:07
【问题描述】:
我有一个存储库类,它的 GetAsQueryable 方法定义如下:
public class Repository<TEntity> : IDisposable, IRepository<TEntity> where TEntity : class
{
internal DbSet<TEntity> _DbSet;
public virtual IQueryable<TEntity> GetAsQueryable(
Expression<Func<TEntity, bool>> filter = null,
Func<IQueryable<TEntity>, IOrderedQueryable<TEntity>> orderBy = null,
string includeProperties = "")
{
IQueryable<TEntity> query = _DbSet;
if (filter != null)
{
query = query.Where(filter);
}
foreach (var includeProperty in includeProperties.Split
(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries))
{
query = query.Include(includeProperty);
}
if (orderBy != null)
{
return orderBy(query);
}
else
{
return query;
}
}
}
在我的调用代码中,我通常会执行以下操作:
IRepository<Tracking> repoTracking = new Repository<Tracking>(context);
IQueryable<Tracking> tracking = repoTracking.GetAsQueryable();
var results = tracking.Where(t => t.Status_Code_Id == 15).ToList();
这很好用;但是现在我希望能够构建在运行时发送到.Where 的 lambda。我尝试构建一个expression tree,如下所示:
IRepository<Tracking> repoTracking = new Repository<Tracking>(context);
IQueryable<Tracking> tracking = repoTracking.GetAsQueryable();
var results = tracking.Where(t => t.Status_Code_Id == 15).ToList();
IRepository<Tracking> repoTracking = new Repository<Tracking>(context);
IQueryable<Tracking> tracking = repoTracking.GetAsQueryable();
ParameterExpression pe = Expression.Parameter(typeof (int), "Status_Code_Id");
LambdaExpression lambda = Expression.Lambda(Expression.Equal(pe, Expression.Constant(15)));
MethodCallExpression whereExpression = Expression.Call(
typeof(Queryable),
"Where",
new Type[] { tracking.ElementType },
tracking.Expression,
lambda);
但是,这会产生以下异常:
类型“System.Linq.Queryable”上没有通用方法“Where”与提供的类型参数和参数兼容。如果方法是非泛型的,则不应提供类型参数。
为什么在我的Tracking 实例上找不到Where 方法?
【问题讨论】: