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