我們在設計架構的時候,使用的EF的時候往往會在參數調用的時候放一個Expression<Func<T, bool>>表示參數。但是在實際的開發中可能需要多參數進行查詢。為此需要擴展一下。
這里先推薦一篇博客,已經有人做過擴展了
拉姆達表達式 追加 條件判斷 Expression<Func<T, bool>>
下面的這段代碼是可以公用的
public static class PredicateBuilder { /// <summary> /// 機關函數應用True時:單個AND有效,多個AND有效;單個OR無效,多個OR無效;混應時寫在AND后的OR有效 /// </summary> /// <typeparam name="T"></typeparam> /// <returns></returns> public static Expression<Func<T, bool>> True<T>() { return f => true; } /// <summary> /// 機關函數應用False時:單個AND無效,多個AND無效;單個OR有效,多個OR有效;混應時寫在OR后面的AND有效 /// </summary> /// <typeparam name="T"></typeparam> /// <returns></returns> public static Expression<Func<T, bool>> False<T>() { return f => false; } public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expr1, Expression<Func<T, bool>> expr2) { var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>()); return Expression.Lambda<Func<T, bool>> (Expression.Or(expr1.Body, invokedExpr), expr1.Parameters); } public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expr1, Expression<Func<T, bool>> expr2) { var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>()); return Expression.Lambda<Func<T, bool>> (Expression.And(expr1.Body, invokedExpr), expr1.Parameters); } }
然后就是接口的定義
public virtual List<T> GetMoreParamesPagedList<TKey>(int pageIndex, int pageSize, Expression<Func<T, bool>> whereLambda, Expression<Func<T, TKey>> orderBy) { return db.Set<T>().Where(whereLambda.Compile()).AsQueryable().OrderBy(orderBy).Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList(); }
接下來就是實現了
var where = PredicateBuilder.True<BaoGaiTouBit>(); where = where.And(e => e.IsEnable); where = where.And(e => e.DeadLine >= mindate); where = where.And(e => e.DeadLine < maxdate); list = OperateContext.Current.BLLSession.IBaoGaiTouBitBLL.GetMoreParamesPagedList(pageIndex, pageSize, where, b => b.CreateTime); return Json(list);
以后這個方法就可以寫到BaseDal中了,作為一個通用的方法,具體的性能如何,希望哪位大牛測試一下。