【发布时间】:2010-09-12 14:47:42
【问题描述】:
所以,我正在尝试找出表达式树。我正在尝试将动态等于添加到 Queryable 中,其中 T 是几个不同的表之一。我首先检查表中是否包含我要过滤的字段。
ParameterExpression param = Expression.Parameter(typeof(TSource), "x");
Expression conversionExpression = Expression.Convert(Expression.Property(param, _sourceProperty), typeof(TList));
Expression<Func<TSource, TList>> propertyExpression = Expression.Lambda<Func<TSource, TList>>(conversionExpression, param);
Expression<Func<TList, TList, bool>> methodExpression = (x, y) => x.Equals(y);
ReadOnlyCollection<ParameterExpression> parameters = propertyExpression.Parameters;
InvocationExpression getFieldPropertyExpression = Expression.Invoke(
propertyExpression,
parameters.Cast<Expression>());
MethodCallExpression methodBody = methodExpression.Body as MethodCallExpression;
MethodCallExpression methodCall = Expression.Call(methodBody.Method, Expression.Constant(equalTo), getFieldPropertyExpression);
Expression<Func<TSource, bool>> equalsStatement = Expression.Lambda<Func<TSource, bool>>(methodCall, parameters);
return source.Where(equalsStatement);
执行此操作时,调用语句中的 MethodInfo 出现问题。它告诉我;
静态方法需要空实例,非静态方法需要非空实例。
我不是表达式树的大师,但我认为我了解我在这里所做的大约 75% 的事情,并且知道我想要实现的目标。 TList 现在是一个坏名字,但我从一个可以很好地生成 In 语句的示例中得到这个。
我真的在这里寻找解释,这样我就可以自己处理代码,或者找到解释我所缺少的内容的解决方案。
编辑:
好的,在经历了一个非常令人沮丧的下午之后,我仍然觉得我完全理解我在看什么,我想我有一个答案。
ParameterExpression sourceObject = Expression.Parameter(typeof(TSource), "x");
Expression<Func<TSource, bool>> check = Expression.Lambda<Func<TSource, bool>>
(
Expression.Equal(
Expression.MakeMemberAccess(sourceObject, typeof(TSource).GetProperty(_sourceProperty)),
Expression.Constant(equalTo)
),
sourceObject
);
return source.Where(check);
有人可以向我解释为什么原版不适合我想要做的事情吗?我想了解更多关于实际过程的信息,但我觉得我没有像我希望的那样快速掌握它。
【问题讨论】: