zoukankan      html  css  js  c++  java
  • ABP Linq 扩展的 WhereIf 查询内部实现

    public static class QueryableExtensions
    {
        public static IQueryable<T> WhereIf<T>(this IQueryable<T> query, bool condition, Expression<Func<T, bool>> predicate)
        {
            return condition ? query.Where(predicate) : query;
        }
    
        public static IQueryable<T> WhereIf<T>(this IQueryable<T> query, bool condition, Expression<Func<T, int, bool>> predicate)
        {
            return condition ? query.Where(predicate) : query;
        }
    
        public static IEnumerable<T> WhereIf<T>(this IEnumerable<T> query, bool condition, Func<T, bool> predicate)
        {
            return condition ? query.Where(predicate) : query;
        }
    }

    上面类中扩展了 IQueryable 与 IEnumerable 两种数据类型的方法。使用方式如下:

    repository.IQueryable<DP_Project>().WhereIf(type > 0, x => x.Type == type);

    这样就替代了原来通过 if 语句判断查询方式。

  • 相关阅读:
    Linux(一)简介与安装
    BBS项目(四)
    BBS项目(三)
    BBS项目(二)
    BBS项目(一)
    会话控制
    SQL表连接查询
    [转]使用GROUP BY WITH ROLLUP改善统计性能
    MySQL中的set和enum
    PHP操作MySQL
  • 原文地址:https://www.cnblogs.com/fxck/p/13076905.html
Copyright © 2011-2022 走看看