Entity Framework分页在我初入门时总是困扰这我,无论是SQL分页还是Entity Framework的分页,总是显得那么麻烦,因此对于Entity Framework单独封装了分页。


一、分页原理

  对于分页本质是针对现有数据进行分段展示,如图:

  对于这12条数据属于筛选后的数据,针对筛选后的数据我们再进行分页,PageSize(每页数量),最后一页数量>0 && <PageSize则算一页。

二、分页设计(对于设计并不是很专业,马马虎虎) 

  

  最终我们通过PageListBase作为实现类,在通过扩展方法ExtensionIQueryable这个一个扩展类,针对IQueryable<T>进行扩展。

  

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Linq.Expressions;
  7. using System.Runtime.Serialization;
  8. using System.Runtime.Serialization.Formatters.Binary;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11.  
  12. namespace Sunc.Framework.Repository.Entity.Extension
  13. {
  14. public static class ExtensionIQueryable
  15. {
  16. /// <summary>
  17. /// 分页
  18. /// </summary>
  19. /// <param name="list"> 数据源 </param>
  20. /// <param name="order"> 排序表达式 </param>
  21. /// <param name="pageIndex"> 第几页 </param>
  22. /// <param name="pageSize"> 每页记录数 </param>
  23. /// <param name="count"> 记录总数 </param>
  24. /// <returns></returns>
  25. public static IQueryable<T> Pagination<T, TKey>(this IQueryable<T> list, Expression<Func<T, bool>> predicate, Expression<Func<T, TKey>> order, int pageIndex, int pageSize, out int count, bool isOrder = true)
  26. {
  27. try
  28. {
  29. var source = list.Where(predicate.Compile()).AsQueryable();
  30. count = source.Count();
  31. if (isOrder)
  32. return source.OrderBy(order).Skip((pageIndex - ) * pageSize).Take(pageSize);
  33. return source.OrderByDescending(order).Skip((pageIndex - ) * pageSize).Take(pageSize);
  34. }
  35. catch (Exception ex)
  36. {
  37. Console.WriteLine(ex.Message);
  38. Debug.WriteLine(ex.Message);
  39. count = ;
  40. return new List<T>().AsQueryable();
  41. }
  42. }
  43.  
  44. public static V ToModel<T, V>(this T t) where T : ModelBase, V where V : ModelBase
  45. {
  46. return t;
  47. }
  48. public static string ToJson(this IQueryable<DatabaseModel> models)
  49. {
  50. return EntityBase.ToJson(models);
  51. }
  52.  
  53. }
  54. }

 三、最终实现

  1、我们使用Entity Framework应该知道懒加载

     public virtual DbSet<T_WindFarm> T_WindFarm { set; get; }

   我们在进行EF一系列表达式操作查询,数据实际并未查询,只用我们真正使用的时候才会执行查询。

  2、EF查询

    ItsmContext 扩展自 DbContext,多线程操作会存在诸多问题,因此我们采用单例模式

    

  1. private static object _asynContextLock = new object();
  2. private static ItsmContext _context;
  3. public static ItsmContext Context
  4. {
  5. get
  6. {
  7. lock (_asynContextLock)
  8. {
  9. if (_context == null)
  10. {
  11. _context = new ItsmContext();
  12. }
  13. return _context;
  14. }
  15. }
  16. }

  3、实现类继承IBaseMethodPageList<Entity>

    

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Linq.Expressions;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using Sunc.Framework.Repository.Entity;
  8.  
  9. namespace Sunc.Framework.Repository.Interface.BaseMethod
  10. {
  11. public interface IBaseMethodPageList<Entity>
  12. {
  13. IBaseEntityPageList<Entity> GetPageList(int pageIndex, int pageSize);
  14.  
  15. IBaseEntityPageList<Entity> GetPageList<TKey>(Expression<Func<Entity, bool>> predicate, Expression<Func<Entity, TKey>> order, int pageIndex, int pageSize, bool isOrder = true);
  16. }
  17. }

  实现类中实现方法

  

  a、using Sunc.Framework.Repository.Entity.Extension;是针对ExtensionIQueryable的引用;

  b、ItsmContext.Context.T_WindFarm.Pagination(predicate, order, pageIndex, pageSize, out count, true);我们通过筛选条件获取PageIndex即为当前页面IQueryable<T>实际结果集;

  c、 var pageList = new PageListBase<T_WindFarm>(models,pageIndex,pageSize,count);我们不用在关心如何去分页,只需要把结果集和总数传入即可;

  d、返回值为IBaseEntityPageList<T_WindFarm> 我们知道它继承于IBasePageList以及它的属性都为只读属性,因此我们可以防止数据被篡改。

4、最终结果

这样一来,我们不用考虑太多的分页问题

  A、ExtensionIQueryable -> Pagination方法帮助我们完成数据筛选得到实际的数据总数并将实际当前页数据、总数返回;

  B、PageListBase<T> 可以通过构造函数或者AddRange方法将当前页数据集加载,通过传入的count计算出实际页数。

具体的源码

Github:Sunc.Framework.Repository
IBasePageList Sunc.Framework.Repository.Interface
IBaseEntityPageList<Entity>  Sunc.Framework.Repository.Interface.BaseMethod
PageListBase<Entity> Sunc.Framework.Repository.Entity
ExtensionIQueryable Sunc.Framework.Repository.Entity.Extension
IBaseMethodPageList<Entity> Sunc.Framework.Repository.Interface.BaseMethod

--分享源于热爱

Sunc

Entity Framework分页扩展的更多相关文章

  1. Entity Framework的扩展库

    https://github.com/jcachat/EntityFramework.DynamicFilters Provides global & scoped filters for E ...

  2. Entity Framework 分页处理

    在SQL中进行分页,网上已经有很多例子了,在这里我使用Linq to SQL让C#来生成分页代码,首先创建分页的扩展方法: public static class Extensions { /// & ...

  3. 采用EntityFramework.Extended 对EF进行扩展(Entity Framework 延伸系列2)

    前言 Entity Framework 延伸系列目录 今天我们来讲讲EntityFramework.Extended 首先科普一下这个EntityFramework.Extended是什么,如下: 这 ...

  4. 《ASP.NET MVC4 WEB编程》学习笔记------Entity Framework的Database First、Model First和Code Only三种开发模式

    作者:张博出处:http://yilin.cnblogs.com Entity Framework支持Database First.Model First和Code Only三种开发模式,各模式的开发 ...

  5. Entity Framework技术系列之0:开篇

    小分享:我有几张阿里云优惠券,用券购买或者升级阿里云相应产品最多可以优惠五折!领券地址:https://promotion.aliyun.com/ntms/act/ambassador/shareto ...

  6. EF3:Entity Framework三种开发模式实现数据访问

    前言 Entity Framework支持Database First.Model First和Code Only三种开发模式,各模式的开发流程大相径庭,开发体验完全不一样.三种开发模式各有优缺点,对 ...

  7. Entity Framework:三种开发模式实现数据访问

    原文地址 http://blog.csdn.net/syaguang2006/article/details/19606715 前言 Entity Framework支持Database First. ...

  8. 《Entity Framework 6 Recipes》中文翻译系列 (17) -----第三章 查询之分页、过滤和使用DateTime中的日期部分分组

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 3-12 分页和过滤 问题 你想使用分页和过滤来创建查询. 解决方案 假设你有如图3 ...

  9. Entity Framework后台采用分页方式取数据与AspNetPager控件的使用

    本文是一个对AspNetPager控件使用的笔记! 有关AspNetPager控件可以查看杨涛主页.这是一个开放的自定义ASP.NET控件,支持各种自定义的数据分页方式,使用很方便,而且功能也很强大, ...

随机推荐

  1. java 的序列化和反序列化的问题

    引言 将 Java 对象序列化为二进制文件的 Java 序列化技术是 Java 系列技术中一个较为重要的技术点,在大部分情况下,开发人员只需要了解被序列化的类需要实现 Serializable 接口, ...

  2. Chapter 1 Securing Your Server and Network(13):配置端点安全性

    原文出处:http://blog.csdn.net/dba_huangzj/article/details/38489765,专题目录:http://blog.csdn.net/dba_huangzj ...

  3. linux 下检查java jar包 程序是否正常 shell

    linux 下检查java jar包 程序是否正常 shell http://injavawetrust.iteye.com BATCH_SERVER="batch.jar" NR ...

  4. AngularJS进阶(三十五)浏览器兼容性解决之道

    浏览器兼容性解决之道 前言 浏览器兼容性一直是前端开发中不得不面对的一个问题.而最突出的就是IE.对绝大多数公司来说,兼容IE6的性价比已经很低,而IE7则几乎已经绝迹.所以,常见的兼容性下限是IE8 ...

  5. Android OnLowMemory和OnTrimMemory

    1.OnLowMemory 是Android提供的API,在系统内存不足,所有后台程序(优先级为background的进程,不是指后台运行的进程)都被杀死时,系统会调用OnLowMemory. 系统提 ...

  6. 如何来看单片机外设A/D转换器ADC0804时序图

    如图,为单片机AD转换器的一种: ADC0804单片集成A/D转换器.它采用CMOS工艺20引脚集成芯片,分辩率为8位,转换时间为100µs,输入电压范围为0-5V.芯片内具有三态输出数据锁存器,可直 ...

  7. Android服务器——使用TomCat实现软件的版本检测,升级,以及下载更新进度!

    Android服务器--使用TomCat实现软件的版本检测,升级,以及下载更新进度! 算下来,TomCat服务器已经写了很长一段时间了,一直说拿他来搞点事 情,也一直没做,今天刚好有空,交流群还有人请 ...

  8. Linux文件与目录管理 - ls, cp, mv

    [root@www ~]# ls [-aAdfFhilnrRSt] 目录名称 [root@www ~]# ls [--color={never,auto,always}] 目录名称 [root@www ...

  9. ActiveMQ系列之四:用ActiveMQ构建应用

    Broker:相当于一个ActiveMQ服务器实例 命令行启动参数示例如下: 1:activemq start :使用默认的activemq.xml来启动 2:activemq start xbean ...

  10. Github搜索技巧-如何使用github找到自己感兴趣的项目

    Github现在不仅仅作为一个版本控制工具,更是一个开源的仓库,里面不但有优秀的开源代码,电子书,还有一些五花八门的项目,有些国家的法律也放在上面,作为程序员如何找到自己感兴趣的项目就非常重要了! 欢 ...