2

下面的代码有效,但我想介绍一个ToUpper()

var predicate =
    Expression.Lambda<Func<T, bool>>(
        Expression.Call(
            Expression.PropertyOrField(parameter, "FirstName"),
            "Contains", null,
            Expression.Constant("myvalue".ToUpper())), parameter
        );

结果是:

{Param_0 => Param_0.FirstName.Contains("MYVALUE")}

但我想要这个:

{Param_0 => Param_0.FirstName.ToUpper().Contains("MYVALUE")}

我该如何改变?

4

2 回答 2

8

只需添加一个Expression.Call

var predicate =
    Expression.Lambda<Func<T, bool>>(
        Expression.Call(
            Expression.Call( // <=== this one is new
                Expression.PropertyOrField(parameter, "FirstName"),
                "ToUpper", null),
            "Contains", null,
            Expression.Constant("myvalue".ToUpper())), parameter
        );

然后将其自身报告为:

Param_0 => Param_0.FirstName.ToUpper().Contains("MYVALUE")
于 2012-12-21T10:03:01.400 回答
5

编辑:好的,我误读了这个问题。问题是您Contains直接调用FirstName属性的结果。您需要先致电ToUpper该物业,例如

var firstName = Expression.PropertyOrField(parameter, "FirstName");
var firstNameUpper = Expression.Call(firstName, "ToUpper", null);
var target = Expression.Constant("myvalue".ToUpper());
var contains = Expression.Call(firstNameToUpper, "Contains", null, target);
var lambda = Expression.Lambda<Func<T, bool>>(contains, parameter);

请注意,这不是“文化上安全的”——使用不区分大小写的比较会更安全。这个问题显示了一种使用 的方法IndexOf,但是您的 LINQ 提供程序可能不支持这种方法(我不知道您之后对这个表达式树做了什么)。

于 2012-12-21T08:25:30.380 回答