1

我目前有 Lambda 表达式:http: //pastebin.com/ZGCiQdHe

我在第 53 行 http://msdn.microsoft.com/en-us/library/bb340145(v=vs.90).aspx得到 ArgumentException

var lExpresion = Expression.Lambda<Func<TEntity, bool>>(body, parametrsNumber, parametrsTyp, parametrsLp);

但我不明白我做错了什么。

我想得到:

    WHERE ((twr_gidnumer =1 and twr_gidtyp = 1 and twr_gidlp = 1) OR 
    (twr_gidnumer =1 and twr_gidtyp = 1 and twr_gidlp = 2))

--回答完整

根据文章:

http://blogs.msdn.com/b/mattwar/archive/2007/07/31/linq-building-an-iqueryable-provider-part-ii.aspx https://stackoverflow.com/Converting 2 参数 Lambda 表达式到 1 个参数 Lambda 表达式

public static Expression<Func<CDNXL_TwrKarty, bool>> Bind2nd(Expression<Func<CDNXL_TwrKarty, CDNXL_TwrKarty,CDNXL_TwrKarty, bool>> source)
{
    Expression newBody = new Rewriter(source.Parameters[0]).Visit(source.Body);
    return Expression.Lambda<Func<CDNXL_TwrKarty, bool>>(newBody, source.Parameters[0]);
}

internal class Rewriter : ExpressionVisitor
{
    private readonly ParameterExpression candidate_;

    public Rewriter(ParameterExpression candidate)
    {
        candidate_ = candidate;
    }

    protected override Expression VisitParameter(ParameterExpression p)
    {
        return candidate_;
    }
}
//REPLACE EXECUTING PLACE
var retMultiLamnda = Expression.Lambda<Func<CDNXL_TwrKarty, CDNXL_TwrKarty, CDNXL_TwrKarty, bool>>(body, parametrsNumber, parametrsTyp, parametrsLp);
var retOneLambda = Bind2nd(retMultiLamnda);
var retQuery = query.Where(retOneLambda);
return retQuery;

感谢 Rafal的帮助。

4

1 回答 1

1

我看到的第一件事是您的委托类型与您的调用列表不匹配。您希望创建接收一个类型参数的函数,TEntity但您将树形参数表达式传递给函数。请注意,您执行此Lablda 方法的重载。

好的,我会尝试更清楚:

Expression.Lambda<Func<Arg1Type,...,ArgNType,ReturnType>>
    (body,parameterExpressionForArg1,...,parameterExpressionForArgN);

这些通用参数ArgType必须与parameterExpressionsForArg. 参数的泛型类型必须与参数的参数表达式数量相同。并且这些类型也必须匹配。

因此,如果您出于某种原因想要拥有树parameterExpressions,那么您的方法中必须有树参数:

 Expression.Lambda<Func<CDNXL_TwrKarty,CDNXL_TwrKarty,CDNXL_TwrKarty, bool>>(body, parametrsNumber, parametrsTyp, parametrsLp); 

在这种情况下可能是正确的调用,显然它不会匹配Where调用。

如果要将树表达式合并到一个匹配Where的参数中,则必须替换所有冗余ParamteterExpressions的 .

于 2012-10-11T06:59:41.700 回答