c# – 如何使用System.Linq.Expressions.Expression过滤基于子节点?

前端之家收集整理的这篇文章主要介绍了c# – 如何使用System.Linq.Expressions.Expression过滤基于子节点?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个过滤器,我使用跨许多方法
Expression<Func<Child,bool>> filter = child => child.Status == 1;

(实际上比这更复杂)

我必须做以下事情

return db.Parents.Where(parent => parent.Status == 1 &&
                                  parent.Child.Status == 1);

条件与上述过滤器相同.

我想在此方法中重用该过滤器.但我不知道如何.我试过了

return db.Parents.Where(parent => parent.Status == 1 &&
                                  filter(parent.Child));

但是Expression不能用作一种方法

解决方法

如果要组合表达式并仍然可以使用linq-to-sql,您可能需要查看 LinqKit.它会在表达式中进行操作,并在sql转换之前通过其内容替换所有的函数调用.

这样你就可以直接使用

return db.Parents
       .AsExpandable()
       .Where(parent => parent.Status == 1 && filter(parent.Child));

猜你在找的C#相关文章