先来看看几个LINQ to sql的几个函数。
Take
说明:获得集合的前n个元素;延迟。即只返回限定数量的结果集。
var q = (
from e in db.Employees
orderby e.HireDate
select e)
.Take(5);
语句描写:选择所雇用的前5个雇员。
Skip
说明:跳过集合的前n个元素;延迟。即我们跳过给定的数目返回后面的结果集。
var q = (
from p in db.Products
orderby p.UnitPrice descending
select p)
.Skip (10);
语句描写:选择10种最贵产品以外的所有产品。
OrderBy
适用处景:对查询出的语句进行排序,比如按时间排序 等等。
说明:按指定表达式对集合排序;延迟,:按指定表达式对集合 排序;延迟,默许是升序,加上descending表示降序,对应的扩大方法是 OrderBy和OrderByDescending
下面这个例子使用 orderby 按雇用日期对雇员进行排序:
var q =
from e in db.Employees
orderby e.HireDate
select e;
说明:默许为升序
看完这两个函数的使用方法,那末分页的思路也就很容易推出来了,若要显示第m页,每页n条数据,我们应当跳过n*(m⑴)条数据,显示n条数据。
源码以下:
/// <summary>
///
分页查询 + 条件
查询 + 排序
/// </summary>
/// <typep
aram name=Tkey>泛型</typep
aram>
/// <p
aram name=pageSize>每页大小</p
aram>
/// <p
aram name=pageIndex>当前
页码</p
aram>
/// <p
aram name=total>总
数量</p
aram>
/// <p
aram name=whereLambda>
查询条件</p
aram>
/// <p
aram name=orderbyLambda>排序条件</p
aram>
/// <p
aram name=isAsc>是不是升序</p
aram>
/// <returns>IQueryable 泛型集合</returns>
public IQueryable<T> LoadPageItems<Tkey>(int pageSize,int pageIndex,out int total,Expression<Func<T,bool>> whereLambda,Func<T,Tkey> orderbyLambda,bool isAsc)
{
total = MyBaseDbContext.Set<T>().Where(whereLambda).Count();
if (isAsc)
{
var temp = MyBaseDbContext.Set<T>().Where(whereLambda)
.OrderBy<T,Tkey>(orderbyLambda)
.Skip(pageSize * (pageIndex - 1))
.Take(pageSize);
return temp.AsQueryable();
}
else
{
var temp = MyBaseDbContext.Set<T>().Where(whereLambda)
.OrderByDescending<T,Tkey>(orderbyLambda)
.Skip(pageSize * (pageIndex - 1))
.Take(pageSize);
return temp.AsQueryable();
}
}
使用示例
//查询要求:每页10条,显示第2页,查询性别为“男”,按年龄增序排列
int totalRecord;
List<Student>result = studentService.LoadItems(10,2,out totalRecord,u=>u.Sex==”男”,u=>u.Age,True);
最近研究了点Linq to sql的知识,发现还挺成心思的,欢迎大家和我1起交换。