运维开发网

如何使用自定义扩展方法使用C#Linq谓词

运维开发网 https://www.qedev.com 2020-03-11 20:25 出处:网络 作者:运维开发网整理
我正在尝试编写一个C#扩展方法,它应该采用Predicate并返回IQueryable,这样我就可以重用一个复杂的Where Predicate 这是我正在看的 public static IEnumerable<T> AddComplexWhere<T>(this IEnumerable<T> query, DBContext context, Func<T, string> Permissio
我正在尝试编写一个C#扩展方法,它应该采用Predicate并返回IQueryable,这样我就可以重用一个复杂的Where Predicate

这是我正在看的

public static IEnumerable<T> AddComplexWhere<T>(this IEnumerable<T> query, DBContext context, Func<T, string> PermissionKeyColumn)
    {
        return query.Where(pp => context.Permissions
            .Where(p => /*PermissionKeyColumn is in Permissions Table p.PermissionKey  ??????*/)
            .Where(p => true/* another complicated where*/).Any());
    }

用法将是

context.orders.AddComplexWhere(context,o=>o.permissionKey).ToList()..

这样我就可以继续重复使用

要实现这一目标,您需要使用

Expression<Func<T, bool>>

这是一个例子:

public static IEnumerable<T> AddComplexWhere<T>(this IEnumerable<T> query, DBContext context, Expression<Func<T, bool>> expression)
    {
        return query.Where(expression).Any());
    }

在此修改之后,您的代码应该正常工作:

context.orders.AddComplexWhere(context,o=>o.permissionKey == something).ToList()..
0

精彩评论

暂无评论...
验证码 换一张
取 消