EF分页


  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);

    

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值