How to build this complex Linq expression?

I want to create a System.Linq.Expression from a List string as follows:

System.Linq.Expressions.Expression x = null;

foreach (string s in GetWords(input))
{
    /* Create Expression */
}

so that I can use:

.Where(x =>
         x.Name.Like(string.Format("%{0}%", word1)) ||
         x.Name.Like(string.Format("%{0}%", word2)) ||
         x.Name.Like(string.Format("%{0}%", word3)) ||
         x.Id.ToString().Like(string.Format("%{0}%", word1)) ||
         x.Id.ToString().Like(string.Format("%{0}%", word2)) ||
         x.Id.ToString().Like(string.Format("%{0}%", word3)) ||
       );

x MyObject

+3
source share
1 answer

Sort of:

string[] words = { "foo", "bar", "blop" }; // your data

Expression body = null;
var param = Expression.Parameter(typeof(SomeType), "x");
var id = Expression.PropertyOrField(param, "Id");
var name = Expression.PropertyOrField(param, "Name");
foreach (string word in words)
{
    var wordExpr = Expression.Constant(word, typeof(string));
    var wordTest = Expression.OrElse(
        Expression.Call(id, "Contains", null, wordExpr),
        Expression.Call(name, "Contains", null, wordExpr));
    body = body == null ? wordTest : Expression.OrElse(body, wordTest);
}
Expression<Func<SomeType,bool>>lambda;
if (body == null) { lambda = x => false; }
else { lambda = Expression.Lambda<Func<SomeType, bool>>(body, param); }
+3
source

Source: https://habr.com/ru/post/1717811/


All Articles