Expression >多參數擴展


我們在設計架構的時候,使用的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中了,作為一個通用的方法,具體的性能如何,希望哪位大牛測試一下。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM