加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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));

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读