我想要的是,如果我有像'e =>这样的表达式e.Name'和值'Brad',我想把它组成/修改为'e => e.Name.Contain(“Brad”)'或'e => e.Name ==“Brad”'。
我写的如下:
public Expression<Func<TModel, bool>> ToBool(Expression<Func<TModel, object>> source, string value)
{
ParameterExpression paramExpression = Expression.Parameter(typeof(TModel), "u");
ConstantExpression valueExpression = Expression.Constant(value, typeof(string));
BinaryExpression equalValue = Expression.MakeBinary(ExpressionType.Equal, source.Body, valueExpression);
Expression<Func<TModel, bool>> lambdaResult = Expression.Lambda<Func<TModel, bool>>(equalValue, new ParameterExpression[] { paramExpression });
return lambdaResult;
}
当触发查询时,我不断收到错误“参数u未绑定在指定的LINQ to Entities查询表达式中”。
请你指出我在这里做错了什么?
非常感谢你的帮助
答案 0 :(得分:1)
source.Body
引用原始lambda中的ParameterExpression
,你从未在新lambda中声明过。{
1}}
您的新u
参数永远不会被使用。
您应该重复使用source.Parameters[0]
而不是创建新参数。