我们在设计架构的时候,使用的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中了,作为一个通用的方法,具体的性能如何,希望哪位大牛测试一下。
