Expression.Lambda和运行时的查询生成,嵌套属性"Where"示例

Pio*_*cki 9 c# lambda dynamic-language-runtime expression-trees

我找到了关于为Where查询构建表达式树的问题的非常好的答案.

Expression.Lambda和运行时的查询生成,最简单的"Where"示例

有人可以帮助我,并告诉我如何在具有嵌套属性的场景中实现此示例.我的意思是代替:

var result = query.Where(item => item.Name == "Soap")
Run Code Online (Sandbox Code Playgroud)

有了这个解决方案

var item = Expression.Parameter(typeof(Item), "item");

var prop = Expression.Property(item, "Name");

var soap = Expression.Constant("Soap");

var equal = Expression.Equal(prop, soap);

var lambda = Expression.Lambda<Func<Item, bool>>(equal, item);

var result = queryableData.Where(lambda);
Run Code Online (Sandbox Code Playgroud)

如何为以下构建树?

var result = query.Where(item => item.Data.Name == "Soap").
Run Code Online (Sandbox Code Playgroud)

Fer*_*oto 2

(这个答案最初是由问题中的OP发布的。)

该问题可以通过以下方式解决:

var item = Expression.Parameter(typeof(Item), "item");

var dataExpr = Expression.Property(item, "Data");

var prop = Expression.Property(dataExpr, "Name");

var soap = Expression.Constant("Soap");

var equal = Expression.Equal(prop, soap);

var lambda = Expression.Lambda<Func<Item, bool>>(equal, item);

var result = queryableData.Where(lambda);
Run Code Online (Sandbox Code Playgroud)