Linq表达式开窍

static IQueryable<T> GetPageList<T,TKey>(Expression<Func<T,bool>> whereLambda,Expression<Func<T,TKey>> orderLambda,int pageSize,int pageIndex)
where T:class 
{
DbContext context=new T1Context();
var result = context.Set<T>()
.Where(whereLambda)
.OrderByDescending(orderLambda) //将数据降序排列
.Skip((pageIndex - 1) * pageSize)
.Take(pageSize)
.Select(c=>c);
return result;
}

 上面值的返回类型是IQueryable,为什么是这个类型呢?

我们可以随便将一个方法,F12转到定义,比如.Take吧

可以看到每个方法的返回类型都是IQueryable,那么你就懂了吧,哈哈~

--------

调用代码块:

var result = GetPageList<CustomerInfo,int>(
c=>c.CustomerName.Length<3,
c=>c.CustomerId,
pageSize, pageIndex);

 foreach (var obj in result)
 {
 Console.WriteLine(obj.CustomerName);
 }

 

 

-------------------------------

以上代码是一个分页查询的简单写法,其中T,TKey代表的是泛型。及代表同一种类型,这里的T代表是同一个类(CustomerInfo类),TKey代表都是int类型。

TKey是T的一个属性,根据这个属性进行排序

 

posted @ 2016-05-08 10:00  shuai7boy  阅读(219)  评论(0编辑  收藏  举报