使用三重选择器查询

时间:2012-10-11 06:50:21

标签: c# entity-framework .net-3.5 lambda

我目前正在使用Lambda Expresion:http://pastebin.com/ZGCiQdHe

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

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))

- ANSWERR FULL

基于文章:

http://blogs.msdn.com/b/mattwar/archive/2007/07/31/linq-building-an-iqueryable-provider-part-ii.aspx https://stackoverflow.com/Converting 2 argument Lambda expression to 1 argument Lambda expression

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;

Thanx Rafal寻求帮助。

1 个答案:

答案 0 :(得分:1)

我看到的第一件事是您的委托类型不会使用您的调用列表进行数学运算。您希望创建一个函数来接收一个类型为TEntity的参数,然后将树参数表达式传递给函数。请注意,您执行Lablda method的重载。

好的,我会更加清楚:

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