c# – 如何使用System.Linq.Expressions.Expression过滤基于子节
发布时间:2020-12-15 17:44:23 所属栏目:百科 来源:网络整理
导读:我有一个过滤器,我使用跨许多方法: ExpressionFuncChild,bool filter = child = child.Status == 1; (实际上比这更复杂) 我必须做以下事情 return db.Parents.Where(parent = parent.Status == 1 parent.Child.Status == 1); 条件与上述过滤器相同. 我想在
我有一个过滤器,我使用跨许多方法:
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)); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |