zoukankan      html  css  js  c++  java
  • EF分页

    先来看看几个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-1)条数据,显示n条数据。

    源码如下:

    [csharp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. /// <summary>  
    2.        /// 分页查询 + 条件查询 + 排序  
    3.        /// </summary>  
    4.        /// <typeparam name="Tkey">泛型</typeparam>  
    5.        /// <param name="pageSize">每页大小</param>  
    6.        /// <param name="pageIndex">当前页码</param>  
    7.        /// <param name="total">总数量</param>  
    8.        /// <param name="whereLambda">查询条件</param>  
    9.        /// <param name="orderbyLambda">排序条件</param>  
    10.        /// <param name="isAsc">是否升序</param>  
    11.        /// <returns>IQueryable 泛型集合</returns>  
    12.        public IQueryable<T> LoadPageItems<Tkey>(int pageSize, int pageIndex, out int total, Expression<Func<T, bool>> whereLambda, Func<T, Tkey> orderbyLambda, bool isAsc)  
    13.        {  
    14.            total = MyBaseDbContext.Set<T>().Where(whereLambda).Count();  
    15.            if (isAsc)  
    16.            {  
    17.                var temp = MyBaseDbContext.Set<T>().Where(whereLambda)  
    18.                             .OrderBy<T, Tkey>(orderbyLambda)  
    19.                             .Skip(pageSize * (pageIndex - 1))  
    20.                             .Take(pageSize);  
    21.                return temp.AsQueryable();  
    22.            }  
    23.            else  
    24.            {  
    25.                var temp = MyBaseDbContext.Set<T>().Where(whereLambda)  
    26.                           .OrderByDescending<T, Tkey>(orderbyLambda)  
    27.                           .Skip(pageSize * (pageIndex - 1))  
    28.                           .Take(pageSize);  
    29.                return temp.AsQueryable();  
    30.            }  
    31.        }  

    使用示例

        //查询要求:每页10条,显示第2页,查询性别为“男”,按年龄增序排列

        int totalRecord;

        List<Student>result = studentService.LoadItems(10,2,out totalRecord,u=>u.Sex==”男”,u=>u.Age,True);

  • 相关阅读:
    Windows程序设计03:创建窗口类
    Android学习笔记19:ImageView实现图片适屏与裁剪
    设计模式01:统一建模语言UML基础知识
    串口通信与编程01:串口基础知识
    Windows程序设计01:在VS2008上新建Windows应用程序项目
    设计模式02:面向对象设计原则
    Windows程序设计02:永恒的Hello World
    Android学习笔记20:Http协议及Java Web编程
    Android学习笔记18:自定义Seekbar拖动条式样
    从 2.4 到 2.6:Linux 内核可装载模块机制的改变对设备驱动的影响
  • 原文地址:https://www.cnblogs.com/Mryang-blog-cn/p/EF_PAGE.html
Copyright © 2011-2022 走看看